diff options
author | Xavier Noria <fxn@hashref.com> | 2014-06-07 13:17:50 +0200 |
---|---|---|
committer | Xavier Noria <fxn@hashref.com> | 2014-06-07 13:19:16 +0200 |
commit | f712f89961b64b61064d99d33dbbfd1903b189d4 (patch) | |
tree | e5357f93588c24325728a8b421a0561a45c31c48 /actionpack | |
parent | 1ecada20d163ec1a3b0a3b6b51922da1dd7f089e (diff) | |
download | rails-f712f89961b64b61064d99d33dbbfd1903b189d4.tar.gz rails-f712f89961b64b61064d99d33dbbfd1903b189d4.tar.bz2 rails-f712f89961b64b61064d99d33dbbfd1903b189d4.zip |
adds a regression test for the strong params converted arrays cache
This is a regression test for 29844dd.
Diffstat (limited to 'actionpack')
-rw-r--r-- | actionpack/test/controller/parameters/parameters_permit_test.rb | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/actionpack/test/controller/parameters/parameters_permit_test.rb b/actionpack/test/controller/parameters/parameters_permit_test.rb index 33a91d72d9..14518d5ebd 100644 --- a/actionpack/test/controller/parameters/parameters_permit_test.rb +++ b/actionpack/test/controller/parameters/parameters_permit_test.rb @@ -167,9 +167,26 @@ class ParametersPermitTest < ActiveSupport::TestCase end end + # Strong params has an optimization to avoid looping every time you read + # a key whose value is an array and building a new object. We check that + # optimization here. test 'arrays are converted at most once' do params = ActionController::Parameters.new(foo: [{}]) - assert params[:foo].equal?(params[:foo]) + assert_same params[:foo], params[:foo] + end + + # Strong params has an internal cache to avoid duplicated loops in the most + # common usage pattern. See the docs of the method `coverted_array`. + # + # This test checks that if we push a hash to an array (in-place modification) + # the cache does not get fooled, the hash is still wrapped as strong params, + # and not permitted. + test 'mutated arrays are detected' do + params = ActionController::Parameters.new(users: [{id: 1}]) + + permitted = params.permit(users: [:id]) + permitted[:users] << {injected: 1} + assert_not permitted[:users].last.permitted? end test "fetch doesnt raise ParameterMissing exception if there is a default" do |