diff options
author | Rafael França <rafaelmfranca@gmail.com> | 2018-07-12 14:13:36 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-07-12 14:13:36 -0400 |
commit | fd132d0dad969b9f05be7eb06b263dab211634f3 (patch) | |
tree | 2cad194d3b4400f86816128f32ef0646b9e4f468 /activesupport | |
parent | 0d864e7eff47ae740b9ea463b46453963ef264cd (diff) | |
parent | 48b6bacbc534d4be3fa89bc19ea83c357a20e598 (diff) | |
download | rails-fd132d0dad969b9f05be7eb06b263dab211634f3.tar.gz rails-fd132d0dad969b9f05be7eb06b263dab211634f3.tar.bz2 rails-fd132d0dad969b9f05be7eb06b263dab211634f3.zip |
Merge pull request #33341 from Edouard-chin/ec-fix-to-param
e4e1b62 broke `to_param` handling:
Diffstat (limited to 'activesupport')
-rw-r--r-- | activesupport/lib/active_support/core_ext/object/to_query.rb | 7 | ||||
-rw-r--r-- | activesupport/test/core_ext/object/to_query_test.rb | 14 |
2 files changed, 19 insertions, 2 deletions
diff --git a/activesupport/lib/active_support/core_ext/object/to_query.rb b/activesupport/lib/active_support/core_ext/object/to_query.rb index abb461966a..bac6ff9c97 100644 --- a/activesupport/lib/active_support/core_ext/object/to_query.rb +++ b/activesupport/lib/active_support/core_ext/object/to_query.rb @@ -75,11 +75,14 @@ class Hash # # This method is also aliased as +to_param+. def to_query(namespace = nil) - collect do |key, value| + query = collect do |key, value| unless (value.is_a?(Hash) || value.is_a?(Array)) && value.empty? value.to_query(namespace ? "#{namespace}[#{key}]" : key) end - end.compact.sort! * "&" + end.compact + + query.sort! unless namespace.to_s.include?("[]") + query.join("&") end alias_method :to_param, :to_query diff --git a/activesupport/test/core_ext/object/to_query_test.rb b/activesupport/test/core_ext/object/to_query_test.rb index 7593bcfa4d..b0b7ef0913 100644 --- a/activesupport/test/core_ext/object/to_query_test.rb +++ b/activesupport/test/core_ext/object/to_query_test.rb @@ -77,6 +77,20 @@ class ToQueryTest < ActiveSupport::TestCase assert_equal "name=Nakshay&type=human", hash.to_query end + def test_hash_not_sorted_lexicographically_for_nested_structure + params = { + "foo" => { + "contents" => [ + { "name" => "gorby", "id" => "123" }, + { "name" => "puff", "d" => "true" } + ] + } + } + expected = "foo[contents][][name]=gorby&foo[contents][][id]=123&foo[contents][][name]=puff&foo[contents][][d]=true" + + assert_equal expected, URI.decode(params.to_query) + end + private def assert_query_equal(expected, actual) assert_equal expected.split("&"), actual.to_query.split("&") |