OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "net/http/http_stream_factory_impl.h" | 5 #include "net/http/http_stream_factory_impl.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
| 8 #include <vector> |
8 | 9 |
9 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
10 #include "net/base/net_log.h" | 11 #include "net/base/net_log.h" |
11 #include "net/base/test_completion_callback.h" | 12 #include "net/base/test_completion_callback.h" |
12 #include "net/cert/mock_cert_verifier.h" | 13 #include "net/cert/mock_cert_verifier.h" |
13 #include "net/dns/mock_host_resolver.h" | 14 #include "net/dns/mock_host_resolver.h" |
14 #include "net/http/http_auth_handler_factory.h" | 15 #include "net/http/http_auth_handler_factory.h" |
15 #include "net/http/http_network_session.h" | 16 #include "net/http/http_network_session.h" |
16 #include "net/http/http_network_session_peer.h" | 17 #include "net/http/http_network_session_peer.h" |
17 #include "net/http/http_network_transaction.h" | 18 #include "net/http/http_network_transaction.h" |
18 #include "net/http/http_request_info.h" | 19 #include "net/http/http_request_info.h" |
| 20 #include "net/http/http_server_properties.h" |
19 #include "net/http/http_server_properties_impl.h" | 21 #include "net/http/http_server_properties_impl.h" |
20 #include "net/http/http_stream.h" | 22 #include "net/http/http_stream.h" |
21 #include "net/http/transport_security_state.h" | 23 #include "net/http/transport_security_state.h" |
22 #include "net/proxy/proxy_info.h" | 24 #include "net/proxy/proxy_info.h" |
23 #include "net/proxy/proxy_service.h" | 25 #include "net/proxy/proxy_service.h" |
| 26 #include "net/socket/client_socket_handle.h" |
24 #include "net/socket/mock_client_socket_pool_manager.h" | 27 #include "net/socket/mock_client_socket_pool_manager.h" |
| 28 #include "net/socket/next_proto.h" |
25 #include "net/socket/socket_test_util.h" | 29 #include "net/socket/socket_test_util.h" |
26 #include "net/spdy/spdy_session.h" | 30 #include "net/spdy/spdy_session.h" |
27 #include "net/spdy/spdy_session_pool.h" | 31 #include "net/spdy/spdy_session_pool.h" |
| 32 #include "net/spdy/spdy_test_util_common.h" |
| 33 #include "net/ssl/ssl_config_service.h" |
28 #include "net/ssl/ssl_config_service_defaults.h" | 34 #include "net/ssl/ssl_config_service_defaults.h" |
| 35 // This file can be included from net/http even though |
| 36 // it is in net/websockets because it doesn't |
| 37 // introduce any link dependency to net/websockets. |
| 38 #include "net/websockets/websocket_stream_base.h" |
29 #include "testing/gtest/include/gtest/gtest.h" | 39 #include "testing/gtest/include/gtest/gtest.h" |
30 | 40 |
31 namespace net { | 41 namespace net { |
32 | 42 |
33 namespace { | 43 namespace { |
34 | 44 |
35 class MockHttpStreamFactoryImpl : public HttpStreamFactoryImpl { | 45 class UseAlternateProtocolsScopedSetter { |
36 public: | 46 public: |
37 MockHttpStreamFactoryImpl(HttpNetworkSession* session) | 47 UseAlternateProtocolsScopedSetter(bool use_alternate_protocols) |
38 : HttpStreamFactoryImpl(session), | 48 : use_alternate_protocols_(HttpStreamFactory::use_alternate_protocols()) { |
| 49 HttpStreamFactory::set_use_alternate_protocols(use_alternate_protocols); |
| 50 } |
| 51 ~UseAlternateProtocolsScopedSetter() { |
| 52 HttpStreamFactory::set_use_alternate_protocols(use_alternate_protocols_); |
| 53 } |
| 54 |
| 55 private: |
| 56 bool use_alternate_protocols_; |
| 57 }; |
| 58 |
| 59 class MockWebSocketStream : public WebSocketStreamBase { |
| 60 public: |
| 61 enum StreamType { |
| 62 kStreamTypeBasic, |
| 63 kStreamTypeSpdy, |
| 64 }; |
| 65 |
| 66 explicit MockWebSocketStream(StreamType type) : type_(type) {} |
| 67 |
| 68 virtual ~MockWebSocketStream() {} |
| 69 |
| 70 virtual WebSocketStream* AsWebSocketStream() OVERRIDE { return NULL; } |
| 71 |
| 72 StreamType type() const { |
| 73 return type_; |
| 74 } |
| 75 |
| 76 private: |
| 77 const StreamType type_; |
| 78 }; |
| 79 |
| 80 // HttpStreamFactoryImpl subclass that can wait until a preconnect is complete. |
| 81 class MockHttpStreamFactoryImplForPreconnect : public HttpStreamFactoryImpl { |
| 82 public: |
| 83 MockHttpStreamFactoryImplForPreconnect(HttpNetworkSession* session, |
| 84 bool for_websockets) |
| 85 : HttpStreamFactoryImpl(session, for_websockets), |
39 preconnect_done_(false), | 86 preconnect_done_(false), |
40 waiting_for_preconnect_(false) {} | 87 waiting_for_preconnect_(false) {} |
41 | 88 |
42 | 89 |
43 void WaitForPreconnects() { | 90 void WaitForPreconnects() { |
44 while (!preconnect_done_) { | 91 while (!preconnect_done_) { |
45 waiting_for_preconnect_ = true; | 92 waiting_for_preconnect_ = true; |
46 base::MessageLoop::current()->Run(); | 93 base::MessageLoop::current()->Run(); |
47 waiting_for_preconnect_ = false; | 94 waiting_for_preconnect_ = false; |
48 } | 95 } |
(...skipping 21 matching lines...) Expand all Loading... |
70 | 117 |
71 virtual void OnStreamReady( | 118 virtual void OnStreamReady( |
72 const SSLConfig& used_ssl_config, | 119 const SSLConfig& used_ssl_config, |
73 const ProxyInfo& used_proxy_info, | 120 const ProxyInfo& used_proxy_info, |
74 HttpStreamBase* stream) OVERRIDE { | 121 HttpStreamBase* stream) OVERRIDE { |
75 stream_done_ = true; | 122 stream_done_ = true; |
76 if (waiting_for_stream_) | 123 if (waiting_for_stream_) |
77 base::MessageLoop::current()->Quit(); | 124 base::MessageLoop::current()->Quit(); |
78 stream_.reset(stream); | 125 stream_.reset(stream); |
79 used_ssl_config_ = used_ssl_config; | 126 used_ssl_config_ = used_ssl_config; |
| 127 used_proxy_info_ = used_proxy_info; |
| 128 } |
| 129 |
| 130 virtual void OnWebSocketStreamReady( |
| 131 const SSLConfig& used_ssl_config, |
| 132 const ProxyInfo& used_proxy_info, |
| 133 WebSocketStreamBase* stream) OVERRIDE { |
| 134 stream_done_ = true; |
| 135 if (waiting_for_stream_) |
| 136 base::MessageLoop::current()->Quit(); |
| 137 websocket_stream_.reset(stream); |
| 138 used_ssl_config_ = used_ssl_config; |
| 139 used_proxy_info_ = used_proxy_info; |
80 } | 140 } |
81 | 141 |
82 virtual void OnStreamFailed( | 142 virtual void OnStreamFailed( |
83 int status, | 143 int status, |
84 const SSLConfig& used_ssl_config) OVERRIDE {} | 144 const SSLConfig& used_ssl_config) OVERRIDE {} |
85 | 145 |
86 virtual void OnCertificateError( | 146 virtual void OnCertificateError( |
87 int status, | 147 int status, |
88 const SSLConfig& used_ssl_config, | 148 const SSLConfig& used_ssl_config, |
89 const SSLInfo& ssl_info) OVERRIDE {} | 149 const SSLInfo& ssl_info) OVERRIDE {} |
(...skipping 16 matching lines...) Expand all Loading... |
106 waiting_for_stream_ = true; | 166 waiting_for_stream_ = true; |
107 base::MessageLoop::current()->Run(); | 167 base::MessageLoop::current()->Run(); |
108 waiting_for_stream_ = false; | 168 waiting_for_stream_ = false; |
109 } | 169 } |
110 } | 170 } |
111 | 171 |
112 const SSLConfig& used_ssl_config() const { | 172 const SSLConfig& used_ssl_config() const { |
113 return used_ssl_config_; | 173 return used_ssl_config_; |
114 } | 174 } |
115 | 175 |
| 176 const ProxyInfo& used_proxy_info() const { |
| 177 return used_proxy_info_; |
| 178 } |
| 179 |
116 HttpStreamBase* stream() { | 180 HttpStreamBase* stream() { |
117 return stream_.get(); | 181 return stream_.get(); |
118 } | 182 } |
119 | 183 |
| 184 MockWebSocketStream* websocket_stream() { |
| 185 return static_cast<MockWebSocketStream*>(websocket_stream_.get()); |
| 186 } |
| 187 |
| 188 bool stream_done() const { return stream_done_; } |
120 | 189 |
121 private: | 190 private: |
122 bool waiting_for_stream_; | 191 bool waiting_for_stream_; |
123 bool stream_done_; | 192 bool stream_done_; |
124 scoped_ptr<HttpStreamBase> stream_; | 193 scoped_ptr<HttpStreamBase> stream_; |
| 194 scoped_ptr<WebSocketStreamBase> websocket_stream_; |
125 SSLConfig used_ssl_config_; | 195 SSLConfig used_ssl_config_; |
| 196 ProxyInfo used_proxy_info_; |
126 | 197 |
127 DISALLOW_COPY_AND_ASSIGN(StreamRequestWaiter); | 198 DISALLOW_COPY_AND_ASSIGN(StreamRequestWaiter); |
128 }; | 199 }; |
129 | 200 |
| 201 class WebSocketSpdyStream : public MockWebSocketStream { |
| 202 public: |
| 203 explicit WebSocketSpdyStream(SpdySession* spdy_session) |
| 204 : MockWebSocketStream(kStreamTypeSpdy), spdy_session_(spdy_session) {} |
| 205 |
| 206 virtual ~WebSocketSpdyStream() {} |
| 207 |
| 208 SpdySession* spdy_session() { return spdy_session_.get(); } |
| 209 |
| 210 private: |
| 211 scoped_refptr<SpdySession> spdy_session_; |
| 212 }; |
| 213 |
| 214 class WebSocketBasicStream : public MockWebSocketStream { |
| 215 public: |
| 216 explicit WebSocketBasicStream(ClientSocketHandle* connection) |
| 217 : MockWebSocketStream(kStreamTypeBasic), connection_(connection) {} |
| 218 |
| 219 virtual ~WebSocketBasicStream() { |
| 220 connection_->socket()->Disconnect(); |
| 221 } |
| 222 |
| 223 ClientSocketHandle* connection() { return connection_.get(); } |
| 224 |
| 225 private: |
| 226 scoped_ptr<ClientSocketHandle> connection_; |
| 227 }; |
| 228 |
| 229 class WebSocketStreamFactory : public WebSocketStreamBase::Factory { |
| 230 public: |
| 231 virtual ~WebSocketStreamFactory() {} |
| 232 |
| 233 virtual WebSocketStreamBase* CreateBasicStream(ClientSocketHandle* connection, |
| 234 bool using_proxy) OVERRIDE { |
| 235 return new WebSocketBasicStream(connection); |
| 236 } |
| 237 |
| 238 virtual WebSocketStreamBase* CreateSpdyStream( |
| 239 SpdySession* spdy_session, |
| 240 bool use_relative_url) OVERRIDE { |
| 241 return new WebSocketSpdyStream(spdy_session); |
| 242 } |
| 243 }; |
| 244 |
130 struct SessionDependencies { | 245 struct SessionDependencies { |
131 // Custom proxy service dependency. | 246 // Custom proxy service dependency. |
132 explicit SessionDependencies(ProxyService* proxy_service) | 247 explicit SessionDependencies(ProxyService* proxy_service) |
133 : host_resolver(new MockHostResolver), | 248 : host_resolver(new MockHostResolver), |
134 cert_verifier(new MockCertVerifier), | 249 cert_verifier(new MockCertVerifier), |
135 transport_security_state(new TransportSecurityState), | 250 transport_security_state(new TransportSecurityState), |
136 proxy_service(proxy_service), | 251 proxy_service(proxy_service), |
137 ssl_config_service(new SSLConfigServiceDefaults), | 252 ssl_config_service(new SSLConfigServiceDefaults), |
138 http_auth_handler_factory( | 253 http_auth_handler_factory( |
139 HttpAuthHandlerFactory::CreateDefault(host_resolver.get())), | 254 HttpAuthHandlerFactory::CreateDefault(host_resolver.get())), |
(...skipping 16 matching lines...) Expand all Loading... |
156 params.cert_verifier = session_deps->cert_verifier.get(); | 271 params.cert_verifier = session_deps->cert_verifier.get(); |
157 params.transport_security_state = | 272 params.transport_security_state = |
158 session_deps->transport_security_state.get(); | 273 session_deps->transport_security_state.get(); |
159 params.proxy_service = session_deps->proxy_service.get(); | 274 params.proxy_service = session_deps->proxy_service.get(); |
160 params.ssl_config_service = session_deps->ssl_config_service.get(); | 275 params.ssl_config_service = session_deps->ssl_config_service.get(); |
161 params.client_socket_factory = &session_deps->socket_factory; | 276 params.client_socket_factory = &session_deps->socket_factory; |
162 params.http_auth_handler_factory = | 277 params.http_auth_handler_factory = |
163 session_deps->http_auth_handler_factory.get(); | 278 session_deps->http_auth_handler_factory.get(); |
164 params.net_log = session_deps->net_log; | 279 params.net_log = session_deps->net_log; |
165 params.http_server_properties = &session_deps->http_server_properties; | 280 params.http_server_properties = &session_deps->http_server_properties; |
| 281 |
166 return new HttpNetworkSession(params); | 282 return new HttpNetworkSession(params); |
167 } | 283 } |
168 | 284 |
169 struct TestCase { | 285 struct TestCase { |
170 int num_streams; | 286 int num_streams; |
171 bool ssl; | 287 bool ssl; |
172 }; | 288 }; |
173 | 289 |
174 TestCase kTests[] = { | 290 TestCase kTests[] = { |
175 { 1, false }, | 291 { 1, false }, |
176 { 2, false }, | 292 { 2, false }, |
177 { 1, true}, | 293 { 1, true}, |
178 { 2, true}, | 294 { 2, true}, |
179 }; | 295 }; |
180 | 296 |
181 void PreconnectHelperForURL(int num_streams, | 297 void PreconnectHelperForURL(int num_streams, |
182 const GURL& url, | 298 const GURL& url, |
183 HttpNetworkSession* session) { | 299 HttpNetworkSession* session) { |
184 HttpNetworkSessionPeer peer(session); | 300 HttpNetworkSessionPeer peer(session); |
185 MockHttpStreamFactoryImpl* mock_factory = | 301 MockHttpStreamFactoryImplForPreconnect* mock_factory = |
186 new MockHttpStreamFactoryImpl(session); | 302 new MockHttpStreamFactoryImplForPreconnect(session, false); |
187 peer.SetHttpStreamFactory(mock_factory); | 303 peer.SetHttpStreamFactory(mock_factory); |
188 SSLConfig ssl_config; | 304 SSLConfig ssl_config; |
189 session->ssl_config_service()->GetSSLConfig(&ssl_config); | 305 session->ssl_config_service()->GetSSLConfig(&ssl_config); |
190 | 306 |
191 HttpRequestInfo request; | 307 HttpRequestInfo request; |
192 request.method = "GET"; | 308 request.method = "GET"; |
193 request.url = url; | 309 request.url = url; |
194 request.load_flags = 0; | 310 request.load_flags = 0; |
195 | 311 |
196 session->http_stream_factory()->PreconnectStreams( | 312 session->http_stream_factory()->PreconnectStreams( |
(...skipping 261 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
458 socket_data1.set_connect_data(MockConnect(ASYNC, ERR_ADDRESS_UNREACHABLE)); | 574 socket_data1.set_connect_data(MockConnect(ASYNC, ERR_ADDRESS_UNREACHABLE)); |
459 session_deps.socket_factory.AddSocketDataProvider(&socket_data1); | 575 session_deps.socket_factory.AddSocketDataProvider(&socket_data1); |
460 | 576 |
461 // Second connection attempt succeeds | 577 // Second connection attempt succeeds |
462 StaticSocketDataProvider socket_data2; | 578 StaticSocketDataProvider socket_data2; |
463 socket_data2.set_connect_data(MockConnect(ASYNC, OK)); | 579 socket_data2.set_connect_data(MockConnect(ASYNC, OK)); |
464 session_deps.socket_factory.AddSocketDataProvider(&socket_data2); | 580 session_deps.socket_factory.AddSocketDataProvider(&socket_data2); |
465 | 581 |
466 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps)); | 582 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps)); |
467 | 583 |
468 // Now request a stream. It should succeed using the second proxy in the | 584 // Now request a stream. It should succeed using the second proxy in the |
469 // list. | 585 // list. |
470 HttpRequestInfo request_info; | 586 HttpRequestInfo request_info; |
471 request_info.method = "GET"; | 587 request_info.method = "GET"; |
472 request_info.url = GURL("http://www.google.com"); | 588 request_info.url = GURL("http://www.google.com"); |
473 | 589 |
474 SSLConfig ssl_config; | 590 SSLConfig ssl_config; |
475 StreamRequestWaiter waiter; | 591 StreamRequestWaiter waiter; |
476 scoped_ptr<HttpStreamRequest> request( | 592 scoped_ptr<HttpStreamRequest> request( |
477 session->http_stream_factory()->RequestStream( | 593 session->http_stream_factory()->RequestStream( |
478 request_info, DEFAULT_PRIORITY, ssl_config, ssl_config, | 594 request_info, DEFAULT_PRIORITY, ssl_config, ssl_config, |
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
530 int GetSocketPoolGroupCount(ClientSocketPool* pool) { | 646 int GetSocketPoolGroupCount(ClientSocketPool* pool) { |
531 int count = 0; | 647 int count = 0; |
532 scoped_ptr<base::DictionaryValue> dict(pool->GetInfoAsValue("", "", false)); | 648 scoped_ptr<base::DictionaryValue> dict(pool->GetInfoAsValue("", "", false)); |
533 EXPECT_TRUE(dict != NULL); | 649 EXPECT_TRUE(dict != NULL); |
534 base::DictionaryValue* groups = NULL; | 650 base::DictionaryValue* groups = NULL; |
535 if (dict->GetDictionary("groups", &groups) && (groups != NULL)) { | 651 if (dict->GetDictionary("groups", &groups) && (groups != NULL)) { |
536 count = static_cast<int>(groups->size()); | 652 count = static_cast<int>(groups->size()); |
537 } | 653 } |
538 return count; | 654 return count; |
539 } | 655 } |
540 }; | 656 } // namespace |
541 | 657 |
542 TEST(HttpStreamFactoryTest, PrivacyModeUsesDifferentSocketPoolGroup) { | 658 TEST(HttpStreamFactoryTest, PrivacyModeUsesDifferentSocketPoolGroup) { |
543 SessionDependencies session_deps(ProxyService::CreateDirect()); | 659 SessionDependencies session_deps(ProxyService::CreateDirect()); |
544 | 660 |
545 StaticSocketDataProvider socket_data; | 661 StaticSocketDataProvider socket_data; |
546 socket_data.set_connect_data(MockConnect(ASYNC, OK)); | 662 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
547 session_deps.socket_factory.AddSocketDataProvider(&socket_data); | 663 session_deps.socket_factory.AddSocketDataProvider(&socket_data); |
548 | 664 |
549 SSLSocketDataProvider ssl(ASYNC, OK); | 665 SSLSocketDataProvider ssl(ASYNC, OK); |
550 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl); | 666 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl); |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
608 scoped_ptr<HttpStreamRequest> request( | 724 scoped_ptr<HttpStreamRequest> request( |
609 session->http_stream_factory()->RequestStream( | 725 session->http_stream_factory()->RequestStream( |
610 request_info, DEFAULT_PRIORITY, ssl_config, ssl_config, | 726 request_info, DEFAULT_PRIORITY, ssl_config, ssl_config, |
611 &waiter, BoundNetLog())); | 727 &waiter, BoundNetLog())); |
612 | 728 |
613 EXPECT_EQ(LOAD_STATE_RESOLVING_HOST, request->GetLoadState()); | 729 EXPECT_EQ(LOAD_STATE_RESOLVING_HOST, request->GetLoadState()); |
614 | 730 |
615 waiter.WaitForStream(); | 731 waiter.WaitForStream(); |
616 } | 732 } |
617 | 733 |
| 734 TEST(HttpStreamFactoryTest, RequestHttpStream) { |
| 735 SessionDependencies session_deps(ProxyService::CreateDirect()); |
| 736 |
| 737 StaticSocketDataProvider socket_data; |
| 738 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
| 739 session_deps.socket_factory.AddSocketDataProvider(&socket_data); |
| 740 |
| 741 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps)); |
| 742 |
| 743 // Now request a stream. It should succeed using the second proxy in the |
| 744 // list. |
| 745 HttpRequestInfo request_info; |
| 746 request_info.method = "GET"; |
| 747 request_info.url = GURL("http://www.google.com"); |
| 748 request_info.load_flags = 0; |
| 749 |
| 750 SSLConfig ssl_config; |
| 751 StreamRequestWaiter waiter; |
| 752 scoped_ptr<HttpStreamRequest> request( |
| 753 session->http_stream_factory()->RequestStream( |
| 754 request_info, |
| 755 DEFAULT_PRIORITY, |
| 756 ssl_config, |
| 757 ssl_config, |
| 758 &waiter, |
| 759 BoundNetLog())); |
| 760 waiter.WaitForStream(); |
| 761 EXPECT_TRUE(waiter.stream_done()); |
| 762 ASSERT_TRUE(NULL != waiter.stream()); |
| 763 EXPECT_TRUE(NULL == waiter.websocket_stream()); |
| 764 EXPECT_FALSE(waiter.stream()->IsSpdyHttpStream()); |
| 765 |
| 766 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 767 session->GetTransportSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 768 EXPECT_EQ(0, GetSocketPoolGroupCount(session->GetSSLSocketPool( |
| 769 HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 770 EXPECT_TRUE(waiter.used_proxy_info().is_direct()); |
| 771 } |
| 772 |
| 773 TEST(HttpStreamFactoryTest, RequestHttpStreamOverSSL) { |
| 774 SessionDependencies session_deps(ProxyService::CreateDirect()); |
| 775 |
| 776 MockRead mock_read(ASYNC, OK); |
| 777 StaticSocketDataProvider socket_data(&mock_read, 1, NULL, 0); |
| 778 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
| 779 session_deps.socket_factory.AddSocketDataProvider(&socket_data); |
| 780 |
| 781 SSLSocketDataProvider ssl_socket_data(ASYNC, OK); |
| 782 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl_socket_data); |
| 783 |
| 784 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps)); |
| 785 |
| 786 // Now request a stream. |
| 787 HttpRequestInfo request_info; |
| 788 request_info.method = "GET"; |
| 789 request_info.url = GURL("https://www.google.com"); |
| 790 request_info.load_flags = 0; |
| 791 |
| 792 SSLConfig ssl_config; |
| 793 StreamRequestWaiter waiter; |
| 794 scoped_ptr<HttpStreamRequest> request( |
| 795 session->http_stream_factory()->RequestStream( |
| 796 request_info, |
| 797 DEFAULT_PRIORITY, |
| 798 ssl_config, |
| 799 ssl_config, |
| 800 &waiter, |
| 801 BoundNetLog())); |
| 802 waiter.WaitForStream(); |
| 803 EXPECT_TRUE(waiter.stream_done()); |
| 804 ASSERT_TRUE(NULL != waiter.stream()); |
| 805 EXPECT_TRUE(NULL == waiter.websocket_stream()); |
| 806 EXPECT_FALSE(waiter.stream()->IsSpdyHttpStream()); |
| 807 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 808 session->GetTransportSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 809 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 810 session->GetSSLSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 811 EXPECT_TRUE(waiter.used_proxy_info().is_direct()); |
| 812 } |
| 813 |
| 814 TEST(HttpStreamFactoryTest, RequestHttpStreamOverProxy) { |
| 815 SessionDependencies session_deps(ProxyService::CreateFixed("myproxy:8888")); |
| 816 |
| 817 StaticSocketDataProvider socket_data; |
| 818 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
| 819 session_deps.socket_factory.AddSocketDataProvider(&socket_data); |
| 820 |
| 821 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps)); |
| 822 |
| 823 // Now request a stream. It should succeed using the second proxy in the |
| 824 // list. |
| 825 HttpRequestInfo request_info; |
| 826 request_info.method = "GET"; |
| 827 request_info.url = GURL("http://www.google.com"); |
| 828 request_info.load_flags = 0; |
| 829 |
| 830 SSLConfig ssl_config; |
| 831 StreamRequestWaiter waiter; |
| 832 scoped_ptr<HttpStreamRequest> request( |
| 833 session->http_stream_factory()->RequestStream( |
| 834 request_info, |
| 835 DEFAULT_PRIORITY, |
| 836 ssl_config, |
| 837 ssl_config, |
| 838 &waiter, |
| 839 BoundNetLog())); |
| 840 waiter.WaitForStream(); |
| 841 EXPECT_TRUE(waiter.stream_done()); |
| 842 ASSERT_TRUE(NULL != waiter.stream()); |
| 843 EXPECT_TRUE(NULL == waiter.websocket_stream()); |
| 844 EXPECT_FALSE(waiter.stream()->IsSpdyHttpStream()); |
| 845 EXPECT_EQ(0, GetSocketPoolGroupCount( |
| 846 session->GetTransportSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 847 EXPECT_EQ(0, GetSocketPoolGroupCount( |
| 848 session->GetSSLSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 849 EXPECT_EQ(1, GetSocketPoolGroupCount(session->GetSocketPoolForHTTPProxy( |
| 850 HttpNetworkSession::NORMAL_SOCKET_POOL, |
| 851 HostPortPair("myproxy", 8888)))); |
| 852 EXPECT_EQ(0, GetSocketPoolGroupCount(session->GetSocketPoolForSSLWithProxy( |
| 853 HttpNetworkSession::NORMAL_SOCKET_POOL, |
| 854 HostPortPair("myproxy", 8888)))); |
| 855 EXPECT_FALSE(waiter.used_proxy_info().is_direct()); |
| 856 } |
| 857 |
| 858 TEST(HttpStreamFactoryTest, RequestWebSocketBasicStream) { |
| 859 SessionDependencies session_deps(ProxyService::CreateDirect()); |
| 860 |
| 861 StaticSocketDataProvider socket_data; |
| 862 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
| 863 session_deps.socket_factory.AddSocketDataProvider(&socket_data); |
| 864 |
| 865 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps)); |
| 866 |
| 867 // Now request a stream. |
| 868 HttpRequestInfo request_info; |
| 869 request_info.method = "GET"; |
| 870 request_info.url = GURL("ws://www.google.com"); |
| 871 request_info.load_flags = 0; |
| 872 |
| 873 SSLConfig ssl_config; |
| 874 StreamRequestWaiter waiter; |
| 875 WebSocketStreamFactory factory; |
| 876 scoped_ptr<HttpStreamRequest> request( |
| 877 session->websocket_stream_factory()->RequestWebSocketStream( |
| 878 request_info, |
| 879 DEFAULT_PRIORITY, |
| 880 ssl_config, |
| 881 ssl_config, |
| 882 &waiter, |
| 883 &factory, |
| 884 BoundNetLog())); |
| 885 waiter.WaitForStream(); |
| 886 EXPECT_TRUE(waiter.stream_done()); |
| 887 EXPECT_TRUE(NULL == waiter.stream()); |
| 888 ASSERT_TRUE(NULL != waiter.websocket_stream()); |
| 889 EXPECT_EQ(MockWebSocketStream::kStreamTypeBasic, |
| 890 waiter.websocket_stream()->type()); |
| 891 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 892 session->GetTransportSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 893 EXPECT_EQ(0, GetSocketPoolGroupCount( |
| 894 session->GetSSLSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 895 EXPECT_TRUE(waiter.used_proxy_info().is_direct()); |
| 896 } |
| 897 |
| 898 TEST(HttpStreamFactoryTest, RequestWebSocketBasicStreamOverSSL) { |
| 899 SessionDependencies session_deps(ProxyService::CreateDirect()); |
| 900 |
| 901 MockRead mock_read(ASYNC, OK); |
| 902 StaticSocketDataProvider socket_data(&mock_read, 1, NULL, 0); |
| 903 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
| 904 session_deps.socket_factory.AddSocketDataProvider(&socket_data); |
| 905 |
| 906 SSLSocketDataProvider ssl_socket_data(ASYNC, OK); |
| 907 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl_socket_data); |
| 908 |
| 909 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps)); |
| 910 |
| 911 // Now request a stream. |
| 912 HttpRequestInfo request_info; |
| 913 request_info.method = "GET"; |
| 914 request_info.url = GURL("wss://www.google.com"); |
| 915 request_info.load_flags = 0; |
| 916 |
| 917 SSLConfig ssl_config; |
| 918 StreamRequestWaiter waiter; |
| 919 WebSocketStreamFactory factory; |
| 920 scoped_ptr<HttpStreamRequest> request( |
| 921 session->websocket_stream_factory()->RequestWebSocketStream( |
| 922 request_info, |
| 923 DEFAULT_PRIORITY, |
| 924 ssl_config, |
| 925 ssl_config, |
| 926 &waiter, |
| 927 &factory, |
| 928 BoundNetLog())); |
| 929 waiter.WaitForStream(); |
| 930 EXPECT_TRUE(waiter.stream_done()); |
| 931 EXPECT_TRUE(NULL == waiter.stream()); |
| 932 ASSERT_TRUE(NULL != waiter.websocket_stream()); |
| 933 EXPECT_EQ(MockWebSocketStream::kStreamTypeBasic, |
| 934 waiter.websocket_stream()->type()); |
| 935 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 936 session->GetTransportSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 937 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 938 session->GetSSLSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 939 EXPECT_TRUE(waiter.used_proxy_info().is_direct()); |
| 940 } |
| 941 |
| 942 TEST(HttpStreamFactoryTest, RequestWebSocketBasicStreamOverProxy) { |
| 943 SessionDependencies session_deps(ProxyService::CreateFixed("myproxy:8888")); |
| 944 |
| 945 MockRead read(SYNCHRONOUS, "HTTP/1.0 200 Connection established\r\n\r\n"); |
| 946 StaticSocketDataProvider socket_data(&read, 1, 0, 0); |
| 947 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
| 948 session_deps.socket_factory.AddSocketDataProvider(&socket_data); |
| 949 |
| 950 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps)); |
| 951 |
| 952 // Now request a stream. |
| 953 HttpRequestInfo request_info; |
| 954 request_info.method = "GET"; |
| 955 request_info.url = GURL("ws://www.google.com"); |
| 956 request_info.load_flags = 0; |
| 957 |
| 958 SSLConfig ssl_config; |
| 959 StreamRequestWaiter waiter; |
| 960 WebSocketStreamFactory factory; |
| 961 scoped_ptr<HttpStreamRequest> request( |
| 962 session->websocket_stream_factory()->RequestWebSocketStream( |
| 963 request_info, |
| 964 DEFAULT_PRIORITY, |
| 965 ssl_config, |
| 966 ssl_config, |
| 967 &waiter, |
| 968 &factory, |
| 969 BoundNetLog())); |
| 970 waiter.WaitForStream(); |
| 971 EXPECT_TRUE(waiter.stream_done()); |
| 972 EXPECT_TRUE(NULL == waiter.stream()); |
| 973 ASSERT_TRUE(NULL != waiter.websocket_stream()); |
| 974 EXPECT_EQ(MockWebSocketStream::kStreamTypeBasic, |
| 975 waiter.websocket_stream()->type()); |
| 976 EXPECT_EQ(0, GetSocketPoolGroupCount( |
| 977 session->GetTransportSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 978 EXPECT_EQ(0, GetSocketPoolGroupCount( |
| 979 session->GetSSLSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 980 EXPECT_EQ(1, GetSocketPoolGroupCount(session->GetSocketPoolForHTTPProxy( |
| 981 HttpNetworkSession::NORMAL_SOCKET_POOL, |
| 982 HostPortPair("myproxy", 8888)))); |
| 983 EXPECT_EQ(0, GetSocketPoolGroupCount(session->GetSocketPoolForSSLWithProxy( |
| 984 HttpNetworkSession::NORMAL_SOCKET_POOL, |
| 985 HostPortPair("myproxy", 8888)))); |
| 986 EXPECT_FALSE(waiter.used_proxy_info().is_direct()); |
| 987 } |
| 988 |
| 989 TEST(HttpStreamFactoryTest, RequestSpdyHttpStream) { |
| 990 SpdySessionDependencies session_deps(kProtoSPDY3, |
| 991 ProxyService::CreateDirect()); |
| 992 |
| 993 MockRead mock_read(ASYNC, OK); |
| 994 StaticSocketDataProvider socket_data(&mock_read, 1, NULL, 0); |
| 995 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
| 996 session_deps.socket_factory->AddSocketDataProvider(&socket_data); |
| 997 |
| 998 SSLSocketDataProvider ssl_socket_data(ASYNC, OK); |
| 999 ssl_socket_data.SetNextProto(kProtoSPDY3); |
| 1000 session_deps.socket_factory->AddSSLSocketDataProvider(&ssl_socket_data); |
| 1001 |
| 1002 HostPortPair host_port_pair("www.google.com", 443); |
| 1003 scoped_refptr<HttpNetworkSession> |
| 1004 session(SpdySessionDependencies::SpdyCreateSession(&session_deps)); |
| 1005 |
| 1006 // Now request a stream. |
| 1007 HttpRequestInfo request_info; |
| 1008 request_info.method = "GET"; |
| 1009 request_info.url = GURL("https://www.google.com"); |
| 1010 request_info.load_flags = 0; |
| 1011 |
| 1012 SSLConfig ssl_config; |
| 1013 StreamRequestWaiter waiter; |
| 1014 scoped_ptr<HttpStreamRequest> request( |
| 1015 session->http_stream_factory()->RequestStream( |
| 1016 request_info, |
| 1017 DEFAULT_PRIORITY, |
| 1018 ssl_config, |
| 1019 ssl_config, |
| 1020 &waiter, |
| 1021 BoundNetLog())); |
| 1022 waiter.WaitForStream(); |
| 1023 EXPECT_TRUE(waiter.stream_done()); |
| 1024 EXPECT_TRUE(NULL == waiter.websocket_stream()); |
| 1025 ASSERT_TRUE(NULL != waiter.stream()); |
| 1026 EXPECT_TRUE(waiter.stream()->IsSpdyHttpStream()); |
| 1027 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 1028 session->GetTransportSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 1029 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 1030 session->GetSSLSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 1031 EXPECT_TRUE(waiter.used_proxy_info().is_direct()); |
| 1032 } |
| 1033 |
| 1034 TEST(HttpStreamFactoryTest, RequestWebSocketSpdyStream) { |
| 1035 SpdySessionDependencies session_deps(kProtoSPDY3, |
| 1036 ProxyService::CreateDirect()); |
| 1037 |
| 1038 MockRead mock_read(SYNCHRONOUS, ERR_IO_PENDING); |
| 1039 StaticSocketDataProvider socket_data(&mock_read, 1, NULL, 0); |
| 1040 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
| 1041 session_deps.socket_factory->AddSocketDataProvider(&socket_data); |
| 1042 |
| 1043 SSLSocketDataProvider ssl_socket_data(ASYNC, OK); |
| 1044 ssl_socket_data.SetNextProto(kProtoSPDY3); |
| 1045 session_deps.socket_factory->AddSSLSocketDataProvider(&ssl_socket_data); |
| 1046 |
| 1047 HostPortPair host_port_pair("www.google.com", 80); |
| 1048 scoped_refptr<HttpNetworkSession> |
| 1049 session(SpdySessionDependencies::SpdyCreateSession(&session_deps)); |
| 1050 |
| 1051 // Now request a stream. |
| 1052 HttpRequestInfo request_info; |
| 1053 request_info.method = "GET"; |
| 1054 request_info.url = GURL("wss://www.google.com"); |
| 1055 request_info.load_flags = 0; |
| 1056 |
| 1057 SSLConfig ssl_config; |
| 1058 StreamRequestWaiter waiter1; |
| 1059 WebSocketStreamFactory factory; |
| 1060 scoped_ptr<HttpStreamRequest> request1( |
| 1061 session->websocket_stream_factory()->RequestWebSocketStream( |
| 1062 request_info, |
| 1063 DEFAULT_PRIORITY, |
| 1064 ssl_config, |
| 1065 ssl_config, |
| 1066 &waiter1, |
| 1067 &factory, |
| 1068 BoundNetLog())); |
| 1069 waiter1.WaitForStream(); |
| 1070 EXPECT_TRUE(waiter1.stream_done()); |
| 1071 ASSERT_TRUE(NULL != waiter1.websocket_stream()); |
| 1072 EXPECT_EQ(MockWebSocketStream::kStreamTypeSpdy, |
| 1073 waiter1.websocket_stream()->type()); |
| 1074 EXPECT_TRUE(NULL == waiter1.stream()); |
| 1075 |
| 1076 StreamRequestWaiter waiter2; |
| 1077 scoped_ptr<HttpStreamRequest> request2( |
| 1078 session->websocket_stream_factory()->RequestWebSocketStream( |
| 1079 request_info, |
| 1080 DEFAULT_PRIORITY, |
| 1081 ssl_config, |
| 1082 ssl_config, |
| 1083 &waiter2, |
| 1084 &factory, |
| 1085 BoundNetLog())); |
| 1086 waiter2.WaitForStream(); |
| 1087 EXPECT_TRUE(waiter2.stream_done()); |
| 1088 ASSERT_TRUE(NULL != waiter2.websocket_stream()); |
| 1089 EXPECT_EQ(MockWebSocketStream::kStreamTypeSpdy, |
| 1090 waiter2.websocket_stream()->type()); |
| 1091 EXPECT_TRUE(NULL == waiter2.stream()); |
| 1092 EXPECT_NE(waiter2.websocket_stream(), waiter1.websocket_stream()); |
| 1093 EXPECT_EQ(static_cast<WebSocketSpdyStream*>(waiter2.websocket_stream())-> |
| 1094 spdy_session(), |
| 1095 static_cast<WebSocketSpdyStream*>(waiter1.websocket_stream())-> |
| 1096 spdy_session()); |
| 1097 |
| 1098 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 1099 session->GetTransportSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 1100 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 1101 session->GetSSLSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 1102 EXPECT_TRUE(waiter1.used_proxy_info().is_direct()); |
| 1103 } |
| 1104 |
| 1105 TEST(HttpStreamFactoryTest, OrphanedWebSocketStream) { |
| 1106 UseAlternateProtocolsScopedSetter use_alternate_protocols(true); |
| 1107 SpdySessionDependencies session_deps(kProtoSPDY3, |
| 1108 ProxyService::CreateDirect()); |
| 1109 |
| 1110 MockRead mock_read(ASYNC, OK); |
| 1111 StaticSocketDataProvider socket_data(&mock_read, 1, NULL, 0); |
| 1112 socket_data.set_connect_data(MockConnect(ASYNC, OK)); |
| 1113 session_deps.socket_factory->AddSocketDataProvider(&socket_data); |
| 1114 |
| 1115 MockRead mock_read2(ASYNC, OK); |
| 1116 StaticSocketDataProvider socket_data2(&mock_read2, 1, NULL, 0); |
| 1117 socket_data2.set_connect_data(MockConnect(ASYNC, ERR_IO_PENDING)); |
| 1118 session_deps.socket_factory->AddSocketDataProvider(&socket_data2); |
| 1119 |
| 1120 SSLSocketDataProvider ssl_socket_data(ASYNC, OK); |
| 1121 ssl_socket_data.SetNextProto(kProtoSPDY3); |
| 1122 session_deps.socket_factory->AddSSLSocketDataProvider(&ssl_socket_data); |
| 1123 |
| 1124 scoped_refptr<HttpNetworkSession> |
| 1125 session(SpdySessionDependencies::SpdyCreateSession(&session_deps)); |
| 1126 |
| 1127 // Now request a stream. |
| 1128 HttpRequestInfo request_info; |
| 1129 request_info.method = "GET"; |
| 1130 request_info.url = GURL("ws://www.google.com:8888"); |
| 1131 request_info.load_flags = 0; |
| 1132 |
| 1133 session->http_server_properties()->SetAlternateProtocol( |
| 1134 HostPortPair("www.google.com", 8888), |
| 1135 9999, |
| 1136 NPN_SPDY_3); |
| 1137 |
| 1138 SSLConfig ssl_config; |
| 1139 StreamRequestWaiter waiter; |
| 1140 WebSocketStreamFactory factory; |
| 1141 scoped_ptr<HttpStreamRequest> request( |
| 1142 session->websocket_stream_factory()->RequestWebSocketStream( |
| 1143 request_info, |
| 1144 DEFAULT_PRIORITY, |
| 1145 ssl_config, |
| 1146 ssl_config, |
| 1147 &waiter, |
| 1148 &factory, |
| 1149 BoundNetLog())); |
| 1150 waiter.WaitForStream(); |
| 1151 EXPECT_TRUE(waiter.stream_done()); |
| 1152 EXPECT_TRUE(NULL == waiter.stream()); |
| 1153 ASSERT_TRUE(NULL != waiter.websocket_stream()); |
| 1154 EXPECT_EQ(MockWebSocketStream::kStreamTypeSpdy, |
| 1155 waiter.websocket_stream()->type()); |
| 1156 |
| 1157 // Make sure that there was an alternative connection |
| 1158 // which consumes extra connections. |
| 1159 EXPECT_EQ(2, GetSocketPoolGroupCount( |
| 1160 session->GetTransportSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 1161 EXPECT_EQ(1, GetSocketPoolGroupCount( |
| 1162 session->GetSSLSocketPool(HttpNetworkSession::NORMAL_SOCKET_POOL))); |
| 1163 EXPECT_TRUE(waiter.used_proxy_info().is_direct()); |
| 1164 |
| 1165 // Make sure there is no orphaned job. it is already canceled. |
| 1166 ASSERT_EQ(0u, static_cast<HttpStreamFactoryImpl*>( |
| 1167 session->websocket_stream_factory())->num_orphaned_jobs()); |
| 1168 } |
| 1169 |
618 } // namespace | 1170 } // namespace |
619 | 1171 |
620 } // namespace net | 1172 } // namespace net |
OLD | NEW |