class Capybara::Queries::CurrentPathQuery
Public Class Methods
Source
# File lib/capybara/queries/current_path_query.rb, line 9 def initialize(expected_path, **options, &optional_filter_block) super(options) @expected_path = expected_path @options = { url: !@expected_path.is_a?(Regexp) && !::Addressable::URI.parse(@expected_path || '').hostname.nil?, ignore_query: false }.merge(options) @filter_block = optional_filter_block assert_valid_keys end
Calls superclass method
Capybara::Queries::BaseQuery::new
Public Instance Methods
Source
# File lib/capybara/queries/current_path_query.rb, line 35 def failure_message failure_message_helper end
Source
# File lib/capybara/queries/current_path_query.rb, line 39 def negative_failure_message failure_message_helper(' not') end
Source
# File lib/capybara/queries/current_path_query.rb, line 20 def resolves_for?(session) uri = ::Addressable::URI.parse(session.current_url) @actual_path = (options[:ignore_query] ? uri&.omit(:query) : uri).then do |u| options[:url] ? u&.to_s : u&.request_uri end res = if @expected_path.is_a? Regexp @actual_path.to_s.match?(@expected_path) else ::Addressable::URI.parse(@expected_path) == ::Addressable::URI.parse(@actual_path) end res && matches_filter_block?(uri) end
Private Instance Methods
Source
# File lib/capybara/queries/current_path_query.rb, line 51 def failure_message_helper(negated = '') verb = @expected_path.is_a?(Regexp) ? 'match' : 'equal' "expected #{@actual_path.inspect}#{negated} to #{verb} #{@expected_path.inspect}" end
Source
# File lib/capybara/queries/current_path_query.rb, line 45 def matches_filter_block?(url) return true unless @filter_block @filter_block.call(url) end
Source
# File lib/capybara/queries/current_path_query.rb, line 56 def valid_keys %i[wait url ignore_query] end