/usr/lib/ruby/vendor_ruby/capybara/session/matchers.rb is in ruby-capybara 2.10.2-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 | # frozen_string_literal: true
module Capybara
module SessionMatchers
##
# Asserts that the page has the given path.
# By default this will compare against the path+query portion of the full url
#
# @!macro current_path_query_params
# @overload $0(string, options = {})
# @param string [String] The string that the current 'path' should equal
# @overload $0(regexp, options = {})
# @param regexp [Regexp] The regexp that the current 'path' should match to
# @option options [Numeric] :wait (Capybara.default_max_wait_time) Maximum time that Capybara will wait for the current path to eq/match given string/regexp argument
# @option options [Boolean] :url (false) Whether the compare should be done against the full url
# @option options [Boolean] :only_path (false) Whether the compare should be done against just the path protion of the url
# @raise [Capybara::ExpectationNotMet] if the assertion hasn't succeeded during wait time
# @return [true]
#
def assert_current_path(path, options={})
query = Capybara::Queries::CurrentPathQuery.new(path, options)
document.synchronize(query.wait) do
unless query.resolves_for?(self)
raise Capybara::ExpectationNotMet, query.failure_message
end
end
return true
end
##
# Asserts that the page doesn't have the given path.
#
# @macro current_path_query_params
# @raise [Capybara::ExpectationNotMet] if the assertion hasn't succeeded during wait time
# @return [true]
#
def assert_no_current_path(path, options={})
query = Capybara::Queries::CurrentPathQuery.new(path, options)
document.synchronize(query.wait) do
if query.resolves_for?(self)
raise Capybara::ExpectationNotMet, query.negative_failure_message
end
end
return true
end
##
# Checks if the page has the given path.
#
# @macro current_path_query_params
# @return [Boolean]
#
def has_current_path?(path, options={})
assert_current_path(path, options)
rescue Capybara::ExpectationNotMet
return false
end
##
# Checks if the page doesn't have the given path.
#
# @macro current_path_query_params
# @return [Boolean]
#
def has_no_current_path?(path, options={})
assert_no_current_path(path, options)
rescue Capybara::ExpectationNotMet
return false
end
end
end
|