aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-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