diff options
author | Timm <kaspth@gmail.com> | 2013-07-24 18:16:11 +0200 |
---|---|---|
committer | Timm <kaspth@gmail.com> | 2014-06-16 21:03:56 +0200 |
commit | 1b0a4b9351c47140cd6ae6336c1eb52159766d9d (patch) | |
tree | d59529d32aca9b68d49b20041a7604d0148828c4 /actionpack | |
parent | 5f756e3ebeaa195dcda8dd516c320ae21d5cafc8 (diff) | |
download | rails-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')
-rw-r--r-- | actionpack/lib/action_dispatch/testing/assertions/selector.rb | 18 |
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 |