diff options
author | Tom Kadwill <tomkadwill@gmail.com> | 2014-05-02 15:54:35 +0100 |
---|---|---|
committer | Tom Kadwill <tomkadwill@gmail.com> | 2014-05-06 14:58:30 +0100 |
commit | 7d5a858e5ce54d449066ad0a00917248475fa7f0 (patch) | |
tree | a7963435906cc460feab0033f714097e1fbd45c6 /actionpack/test | |
parent | e167a54785e319c526b638d591eaca0c4da93a54 (diff) | |
download | rails-7d5a858e5ce54d449066ad0a00917248475fa7f0.tar.gz rails-7d5a858e5ce54d449066ad0a00917248475fa7f0.tar.bz2 rails-7d5a858e5ce54d449066ad0a00917248475fa7f0.zip |
Moved 'params[request_forgery_protection_token]' into its own method and improved tests.
Diffstat (limited to 'actionpack/test')
-rw-r--r-- | actionpack/test/controller/request_forgery_protection_test.rb | 31 |
1 files changed, 26 insertions, 5 deletions
diff --git a/actionpack/test/controller/request_forgery_protection_test.rb b/actionpack/test/controller/request_forgery_protection_test.rb index 5ab5141966..07c2115832 100644 --- a/actionpack/test/controller/request_forgery_protection_test.rb +++ b/actionpack/test/controller/request_forgery_protection_test.rb @@ -462,16 +462,37 @@ end class CustomAuthenticityParamControllerTest < ActionController::TestCase def setup super - ActionController::Base.request_forgery_protection_token = :custom_token_name + @old_logger = ActionController::Base.logger + @logger = ActiveSupport::LogSubscriber::TestHelper::MockLogger.new + @token = "foobar" + ActionController::Base.request_forgery_protection_token = @token end def teardown - ActionController::Base.request_forgery_protection_token = :authenticity_token + ActionController::Base.request_forgery_protection_token = nil super end - def test_should_allow_custom_token - post :index, :custom_token_name => 'foobar' - assert_response :ok + def test_should_not_warn_if_form_authenticity_param_matches_form_authenticity_token + ActionController::Base.logger = @logger + SecureRandom.stubs(:base64).returns(@token) + + begin + post :index, :custom_token_name => 'foobar' + assert_equal 0, @logger.logged(:warn).size + ensure + ActionController::Base.logger = @old_logger + end + end + + def test_should_warn_if_form_authenticity_param_does_not_match_form_authenticity_token + ActionController::Base.logger = @logger + + begin + post :index, :custom_token_name => 'bazqux' + assert_equal 1, @logger.logged(:warn).size + ensure + ActionController::Base.logger = @old_logger + end end end |