OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "base/memory/scoped_ptr.h" | 5 #include "base/memory/scoped_ptr.h" |
6 #include "net/base/net_errors.h" | 6 #include "net/base/net_errors.h" |
7 #include "net/dns/mock_host_resolver.h" | 7 #include "net/dns/mock_host_resolver.h" |
8 #include "net/http/http_auth_handler.h" | 8 #include "net/http/http_auth_handler.h" |
9 #include "net/http/http_auth_handler_factory.h" | 9 #include "net/http/http_auth_handler_factory.h" |
10 #include "net/http/mock_allow_url_security_manager.h" | 10 #include "net/http/mock_allow_url_security_manager.h" |
11 #include "net/http/url_security_manager.h" | 11 #include "net/http/url_security_manager.h" |
12 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
| 13 #include "url/origin.h" |
13 | 14 |
14 namespace net { | 15 namespace net { |
15 | 16 |
16 namespace { | 17 namespace { |
17 | 18 |
18 class MockHttpAuthHandlerFactory : public HttpAuthHandlerFactory { | 19 class MockHttpAuthHandlerFactory : public HttpAuthHandlerFactory { |
19 public: | 20 public: |
20 explicit MockHttpAuthHandlerFactory(int return_code) : | 21 explicit MockHttpAuthHandlerFactory(int return_code) : |
21 return_code_(return_code) {} | 22 return_code_(return_code) {} |
22 ~MockHttpAuthHandlerFactory() override {} | 23 ~MockHttpAuthHandlerFactory() override {} |
23 | 24 |
24 int CreateAuthHandler(HttpAuthChallengeTokenizer* challenge, | 25 int CreateAuthHandler(HttpAuthChallengeTokenizer* challenge, |
25 HttpAuth::Target target, | 26 HttpAuth::Target target, |
26 const GURL& origin, | 27 const url::Origin& origin, |
27 CreateReason reason, | 28 CreateReason reason, |
28 int nonce_count, | 29 int nonce_count, |
29 const BoundNetLog& net_log, | 30 const BoundNetLog& net_log, |
30 scoped_ptr<HttpAuthHandler>* handler) override { | 31 scoped_ptr<HttpAuthHandler>* handler) override { |
31 handler->reset(); | 32 handler->reset(); |
32 return return_code_; | 33 return return_code_; |
33 } | 34 } |
34 | 35 |
35 private: | 36 private: |
36 int return_code_; | 37 int return_code_; |
37 }; | 38 }; |
38 | 39 |
39 } // namespace | 40 } // namespace |
40 | 41 |
41 TEST(HttpAuthHandlerFactoryTest, RegistryFactory) { | 42 TEST(HttpAuthHandlerFactoryTest, RegistryFactory) { |
42 HttpAuthHandlerRegistryFactory registry_factory; | 43 HttpAuthHandlerRegistryFactory registry_factory; |
43 GURL gurl("www.google.com"); | 44 url::Origin origin("http://www.example.com"); |
44 const int kBasicReturnCode = ERR_INVALID_SPDY_STREAM; | 45 const int kBasicReturnCode = ERR_INVALID_SPDY_STREAM; |
45 MockHttpAuthHandlerFactory* mock_factory_basic = | 46 MockHttpAuthHandlerFactory* mock_factory_basic = |
46 new MockHttpAuthHandlerFactory(kBasicReturnCode); | 47 new MockHttpAuthHandlerFactory(kBasicReturnCode); |
47 | 48 |
48 const int kDigestReturnCode = ERR_PAC_SCRIPT_FAILED; | 49 const int kDigestReturnCode = ERR_PAC_SCRIPT_FAILED; |
49 MockHttpAuthHandlerFactory* mock_factory_digest = | 50 MockHttpAuthHandlerFactory* mock_factory_digest = |
50 new MockHttpAuthHandlerFactory(kDigestReturnCode); | 51 new MockHttpAuthHandlerFactory(kDigestReturnCode); |
51 | 52 |
52 const int kDigestReturnCodeReplace = ERR_SYN_REPLY_NOT_RECEIVED; | 53 const int kDigestReturnCodeReplace = ERR_SYN_REPLY_NOT_RECEIVED; |
53 MockHttpAuthHandlerFactory* mock_factory_digest_replace = | 54 MockHttpAuthHandlerFactory* mock_factory_digest_replace = |
54 new MockHttpAuthHandlerFactory(kDigestReturnCodeReplace); | 55 new MockHttpAuthHandlerFactory(kDigestReturnCodeReplace); |
55 | 56 |
56 scoped_ptr<HttpAuthHandler> handler; | 57 scoped_ptr<HttpAuthHandler> handler; |
57 | 58 |
58 // No schemes should be supported in the beginning. | 59 // No schemes should be supported in the beginning. |
59 EXPECT_EQ(ERR_UNSUPPORTED_AUTH_SCHEME, | 60 EXPECT_EQ( |
60 registry_factory.CreateAuthHandlerFromString( | 61 ERR_UNSUPPORTED_AUTH_SCHEME, |
61 "Basic", HttpAuth::AUTH_SERVER, gurl, BoundNetLog(), &handler)); | 62 registry_factory.CreateAuthHandlerFromString( |
| 63 "Basic", HttpAuth::AUTH_SERVER, origin, BoundNetLog(), &handler)); |
62 | 64 |
63 // Test what happens with a single scheme. | 65 // Test what happens with a single scheme. |
64 registry_factory.RegisterSchemeFactory("Basic", mock_factory_basic); | 66 registry_factory.RegisterSchemeFactory("Basic", mock_factory_basic); |
65 EXPECT_EQ(kBasicReturnCode, | 67 EXPECT_EQ(kBasicReturnCode, registry_factory.CreateAuthHandlerFromString( |
66 registry_factory.CreateAuthHandlerFromString( | 68 "Basic", HttpAuth::AUTH_SERVER, origin, |
67 "Basic", HttpAuth::AUTH_SERVER, gurl, BoundNetLog(), &handler)); | 69 BoundNetLog(), &handler)); |
68 EXPECT_EQ(ERR_UNSUPPORTED_AUTH_SCHEME, | 70 EXPECT_EQ( |
69 registry_factory.CreateAuthHandlerFromString( | 71 ERR_UNSUPPORTED_AUTH_SCHEME, |
70 "Digest", HttpAuth::AUTH_SERVER, gurl, BoundNetLog(), | 72 registry_factory.CreateAuthHandlerFromString( |
71 &handler)); | 73 "Digest", HttpAuth::AUTH_SERVER, origin, BoundNetLog(), &handler)); |
72 | 74 |
73 // Test multiple schemes | 75 // Test multiple schemes |
74 registry_factory.RegisterSchemeFactory("Digest", mock_factory_digest); | 76 registry_factory.RegisterSchemeFactory("Digest", mock_factory_digest); |
75 EXPECT_EQ(kBasicReturnCode, | 77 EXPECT_EQ(kBasicReturnCode, registry_factory.CreateAuthHandlerFromString( |
76 registry_factory.CreateAuthHandlerFromString( | 78 "Basic", HttpAuth::AUTH_SERVER, origin, |
77 "Basic", HttpAuth::AUTH_SERVER, gurl, BoundNetLog(), &handler)); | 79 BoundNetLog(), &handler)); |
78 EXPECT_EQ(kDigestReturnCode, | 80 EXPECT_EQ(kDigestReturnCode, registry_factory.CreateAuthHandlerFromString( |
79 registry_factory.CreateAuthHandlerFromString( | 81 "Digest", HttpAuth::AUTH_SERVER, origin, |
80 "Digest", HttpAuth::AUTH_SERVER, gurl, BoundNetLog(), | 82 BoundNetLog(), &handler)); |
81 &handler)); | |
82 | 83 |
83 // Test case-insensitivity | 84 // Test case-insensitivity |
84 EXPECT_EQ(kBasicReturnCode, | 85 EXPECT_EQ(kBasicReturnCode, registry_factory.CreateAuthHandlerFromString( |
85 registry_factory.CreateAuthHandlerFromString( | 86 "basic", HttpAuth::AUTH_SERVER, origin, |
86 "basic", HttpAuth::AUTH_SERVER, gurl, BoundNetLog(), &handler)); | 87 BoundNetLog(), &handler)); |
87 | 88 |
88 // Test replacement of existing auth scheme | 89 // Test replacement of existing auth scheme |
89 registry_factory.RegisterSchemeFactory("Digest", mock_factory_digest_replace); | 90 registry_factory.RegisterSchemeFactory("Digest", mock_factory_digest_replace); |
90 EXPECT_EQ(kBasicReturnCode, | 91 EXPECT_EQ(kBasicReturnCode, registry_factory.CreateAuthHandlerFromString( |
91 registry_factory.CreateAuthHandlerFromString( | 92 "Basic", HttpAuth::AUTH_SERVER, origin, |
92 "Basic", HttpAuth::AUTH_SERVER, gurl, BoundNetLog(), &handler)); | 93 BoundNetLog(), &handler)); |
93 EXPECT_EQ(kDigestReturnCodeReplace, | 94 EXPECT_EQ( |
94 registry_factory.CreateAuthHandlerFromString( | 95 kDigestReturnCodeReplace, |
95 "Digest", HttpAuth::AUTH_SERVER, gurl, BoundNetLog(), | 96 registry_factory.CreateAuthHandlerFromString( |
96 &handler)); | 97 "Digest", HttpAuth::AUTH_SERVER, origin, BoundNetLog(), &handler)); |
97 } | 98 } |
98 | 99 |
99 TEST(HttpAuthHandlerFactoryTest, DefaultFactory) { | 100 TEST(HttpAuthHandlerFactoryTest, DefaultFactory) { |
100 scoped_ptr<HostResolver> host_resolver(new MockHostResolver()); | 101 scoped_ptr<HostResolver> host_resolver(new MockHostResolver()); |
101 MockAllowURLSecurityManager url_security_manager; | 102 MockAllowURLSecurityManager url_security_manager; |
102 scoped_ptr<HttpAuthHandlerRegistryFactory> http_auth_handler_factory( | 103 scoped_ptr<HttpAuthHandlerRegistryFactory> http_auth_handler_factory( |
103 HttpAuthHandlerFactory::CreateDefault(host_resolver.get())); | 104 HttpAuthHandlerFactory::CreateDefault(host_resolver.get())); |
104 http_auth_handler_factory->SetURLSecurityManager( | 105 http_auth_handler_factory->SetURLSecurityManager( |
105 "negotiate", &url_security_manager); | 106 "negotiate", &url_security_manager); |
106 GURL server_origin("http://www.example.com"); | 107 url::Origin server_origin("http://www.example.com"); |
107 GURL proxy_origin("http://cache.example.com:3128"); | 108 url::Origin proxy_origin("http://cache.example.com:3128"); |
108 { | 109 { |
109 scoped_ptr<HttpAuthHandler> handler; | 110 scoped_ptr<HttpAuthHandler> handler; |
110 int rv = http_auth_handler_factory->CreateAuthHandlerFromString( | 111 int rv = http_auth_handler_factory->CreateAuthHandlerFromString( |
111 "Basic realm=\"FooBar\"", | 112 "Basic realm=\"FooBar\"", |
112 HttpAuth::AUTH_SERVER, | 113 HttpAuth::AUTH_SERVER, |
113 server_origin, | 114 server_origin, |
114 BoundNetLog(), | 115 BoundNetLog(), |
115 &handler); | 116 &handler); |
116 EXPECT_EQ(OK, rv); | 117 EXPECT_EQ(OK, rv); |
117 ASSERT_FALSE(handler.get() == NULL); | 118 ASSERT_FALSE(handler.get() == NULL); |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
181 EXPECT_TRUE(handler->encrypts_identity()); | 182 EXPECT_TRUE(handler->encrypts_identity()); |
182 EXPECT_TRUE(handler->is_connection_based()); | 183 EXPECT_TRUE(handler->is_connection_based()); |
183 #else | 184 #else |
184 EXPECT_EQ(ERR_UNSUPPORTED_AUTH_SCHEME, rv); | 185 EXPECT_EQ(ERR_UNSUPPORTED_AUTH_SCHEME, rv); |
185 EXPECT_TRUE(handler.get() == NULL); | 186 EXPECT_TRUE(handler.get() == NULL); |
186 #endif // defined(USE_KERBEROS) | 187 #endif // defined(USE_KERBEROS) |
187 } | 188 } |
188 } | 189 } |
189 | 190 |
190 } // namespace net | 191 } // namespace net |
OLD | NEW |