diff options
author | Matthew Draper <matthew@trebex.net> | 2014-06-13 23:47:21 +0930 |
---|---|---|
committer | Matthew Draper <matthew@trebex.net> | 2014-06-13 23:47:21 +0930 |
commit | b71d46a81a5798ea4e5ba0f7d41e07f573e6e615 (patch) | |
tree | c94547f4c1b73307b2bbb080b29e4ed20d2dccdd /actionpack/test/controller | |
parent | 1c41d3b9827e839c0fc559b95cb07e45970b5ebb (diff) | |
parent | fdb10597952614456b45460202c0b7c7b8833ecd (diff) | |
download | rails-b71d46a81a5798ea4e5ba0f7d41e07f573e6e615.tar.gz rails-b71d46a81a5798ea4e5ba0f7d41e07f573e6e615.tar.bz2 rails-b71d46a81a5798ea4e5ba0f7d41e07f573e6e615.zip |
Merge pull request #15683 from larrylv/fix-token-with-empty-value
Fix parsed token value with header `Authorization token=`.
Diffstat (limited to 'actionpack/test/controller')
-rw-r--r-- | actionpack/test/controller/http_token_authentication_test.rb | 29 |
1 files changed, 23 insertions, 6 deletions
diff --git a/actionpack/test/controller/http_token_authentication_test.rb b/actionpack/test/controller/http_token_authentication_test.rb index 86b94652ce..ef90fff178 100644 --- a/actionpack/test/controller/http_token_authentication_test.rb +++ b/actionpack/test/controller/http_token_authentication_test.rb @@ -132,13 +132,30 @@ class HttpTokenAuthenticationTest < ActionController::TestCase assert_equal(expected, actual) end - private - - def sample_request(token) - @sample_request ||= OpenStruct.new authorization: %{Token token="#{token}"} + test "token_and_options returns empty string with empty token" do + token = '' + actual = ActionController::HttpAuthentication::Token.token_and_options(sample_request(token)).first + expected = token + assert_equal(expected, actual) end - def encode_credentials(token, options = {}) - ActionController::HttpAuthentication::Token.encode_credentials(token, options) + test "token_and_options returns nil with no value after the equal sign" do + actual = ActionController::HttpAuthentication::Token.token_and_options(malformed_request).first + expected = nil + assert_equal(expected, actual) end + + private + + def sample_request(token) + @sample_request ||= OpenStruct.new authorization: %{Token token="#{token}", nonce="def"} + end + + def malformed_request + @malformed_request ||= OpenStruct.new authorization: %{Token token=} + end + + def encode_credentials(token, options = {}) + ActionController::HttpAuthentication::Token.encode_credentials(token, options) + end end |