diff options
author | Guillermo Iguaran <guilleiguaran@gmail.com> | 2014-01-29 10:48:49 -0800 |
---|---|---|
committer | Guillermo Iguaran <guilleiguaran@gmail.com> | 2014-01-29 10:48:49 -0800 |
commit | b242552430345aedd36bb0ab357089f9a0dc746f (patch) | |
tree | 5e09d9c86629843b036fbd717a5d4f4a1d180eb3 /actionpack/test | |
parent | 40e7fe3451df8e5b454f7d0472396d2429edc0e5 (diff) | |
parent | b23ffd0dac895aa3fd3afd8d9be36794941731b2 (diff) | |
download | rails-b242552430345aedd36bb0ab357089f9a0dc746f.tar.gz rails-b242552430345aedd36bb0ab357089f9a0dc746f.tar.bz2 rails-b242552430345aedd36bb0ab357089f9a0dc746f.zip |
Merge pull request #13692 from lukesarnacki/change-default-session-serializer
Allow session serializer key in config.session_store
Diffstat (limited to 'actionpack/test')
-rw-r--r-- | actionpack/test/dispatch/cookies_test.rb | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/actionpack/test/dispatch/cookies_test.rb b/actionpack/test/dispatch/cookies_test.rb index 91ac13e7c6..b19ce905f5 100644 --- a/actionpack/test/dispatch/cookies_test.rb +++ b/actionpack/test/dispatch/cookies_test.rb @@ -379,6 +379,39 @@ class CookiesTest < ActionController::TestCase assert_equal 'bar', cookies.encrypted[:foo] end + class ActionDispatch::Session::CustomJsonSerializer + def self.load(value) + JSON.load(value) + " and loaded" + end + + def self.dump(value) + JSON.dump(value + " was dumped") + end + end + + def test_encrypted_cookie_using_custom_json_serializer + @request.env["action_dispatch.session_serializer"] = :custom_json_serializer + get :set_encrypted_cookie + assert_equal 'bar was dumped and loaded', cookies.encrypted[:foo] + end + + def test_encrypted_cookie_using_serializer_object + @request.env["action_dispatch.session_serializer"] = ActionDispatch::Session::CustomJsonSerializer + get :set_encrypted_cookie + assert_equal 'bar was dumped and loaded', cookies.encrypted[:foo] + end + + def test_encrypted_cookie_using_json_serializer + @request.env["action_dispatch.session_serializer"] = :json_serializer + get :set_encrypted_cookie + cookies = @controller.send :cookies + assert_not_equal 'bar', cookies[:foo] + assert_raises TypeError do + cookies.signed[:foo] + end + assert_equal 'bar', cookies.encrypted[:foo] + end + def test_accessing_nonexistant_encrypted_cookie_should_not_raise_invalid_message get :set_encrypted_cookie assert_nil @controller.send(:cookies).encrypted[:non_existant_attribute] |