aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_dispatch/testing
diff options
context:
space:
mode:
authorTimm <kaspth@gmail.com>2013-07-24 18:16:11 +0200
committerTimm <kaspth@gmail.com>2014-06-16 21:03:56 +0200
commit1b0a4b9351c47140cd6ae6336c1eb52159766d9d (patch)
treed59529d32aca9b68d49b20041a7604d0148828c4 /actionpack/lib/action_dispatch/testing
parent5f756e3ebeaa195dcda8dd516c320ae21d5cafc8 (diff)
downloadrails-1b0a4b9351c47140cd6ae6336c1eb52159766d9d.tar.gz
rails-1b0a4b9351c47140cd6ae6336c1eb52159766d9d.tar.bz2
rails-1b0a4b9351c47140cd6ae6336c1eb52159766d9d.zip
Changed css_select to not count on multiple selectors. Fixed bug in determine_root_from where @selected was an Array. Changed assert_select_encoded to use a fragment instead of a document.
Diffstat (limited to 'actionpack/lib/action_dispatch/testing')
-rw-r--r--actionpack/lib/action_dispatch/testing/assertions/selector.rb18
1 files changed, 10 insertions, 8 deletions
diff --git a/actionpack/lib/action_dispatch/testing/assertions/selector.rb b/actionpack/lib/action_dispatch/testing/assertions/selector.rb
index 0ba3fffd5a..615f68e622 100644
--- a/actionpack/lib/action_dispatch/testing/assertions/selector.rb
+++ b/actionpack/lib/action_dispatch/testing/assertions/selector.rb
@@ -59,10 +59,10 @@ module ActionDispatch
def css_select(*args)
raise ArgumentError, "you at least need a selector" if args.empty?
- if args.first.is_a?(String) # use nokogiri's ability for more selectors
- root, selectors = response_from_page, args
+ if args.first.is_a?(String)
+ root, selectors = response_from_page, args.first
else
- root, selectors = args.shift, args
+ root, selectors = args.shift, args.first
end
root.css(selectors)
@@ -248,7 +248,7 @@ module ActionDispatch
end
selected = elements.map do |elem|
- root = Loofah.document(CGI.unescapeHTML("<encoded>#{elem.text}</encoded>")).root
+ root = Loofah.fragment(CGI.unescapeHTML("<encoded>#{elem.text}</encoded>"))
css_select(root, "encoded:root", &block)[0]
end
@@ -311,12 +311,10 @@ module ActionDispatch
end
# +equals+ must contain :minimum, :maximum and :count keys
- def assert_size_match!(size, equals, selector, message = nil)
+ def assert_size_match!(size, equals, css_selector, message = nil)
min, max, count = equals[:minimum], equals[:maximum], equals[:count]
- # FIXME: minitest provides messaging when we use assert_operator,
- # so is this custom message really needed?
- message ||= %(Expected #{count_description(min, max, count)} matching "#{selector.to_s}", found #{size}.)
+ message ||= %(Expected #{count_description(min, max, count)} matching "#{css_selector}", found #{size}.)
if count
assert_equal size, count, message
else
@@ -380,6 +378,10 @@ module ActionDispatch
root_or_selector
elsif @selected
# nested call - wrap in document
+ if @selected.is_a?(Array)
+ doc = @selected.empty? ? @page.document : @selected[0].document
+ @selected = Nokogiri::XML::NodeSet.new(doc, @selected)
+ end
Loofah.fragment('').tap { |d| d.add_child @selected }
else
@page