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 <vector> | 5 #include <vector> |
6 | 6 |
7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" |
9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
10 #include "base/stl_util.h" | 10 #include "base/stl_util.h" |
11 #include "net/base/test_completion_callback.h" | 11 #include "net/base/test_completion_callback.h" |
| 12 #include "net/base/test_data_directory.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_transaction.h" | 17 #include "net/http/http_network_transaction.h" |
17 #include "net/http/http_server_properties_impl.h" | 18 #include "net/http/http_server_properties_impl.h" |
18 #include "net/http/http_stream.h" | 19 #include "net/http/http_stream.h" |
19 #include "net/http/http_stream_factory.h" | 20 #include "net/http/http_stream_factory.h" |
20 #include "net/http/http_transaction_test_util.h" | 21 #include "net/http/http_transaction_test_util.h" |
21 #include "net/http/transport_security_state.h" | 22 #include "net/http/transport_security_state.h" |
22 #include "net/log/test_net_log.h" | 23 #include "net/log/test_net_log.h" |
23 #include "net/log/test_net_log_entry.h" | 24 #include "net/log/test_net_log_entry.h" |
24 #include "net/log/test_net_log_util.h" | 25 #include "net/log/test_net_log_util.h" |
25 #include "net/proxy/proxy_config_service_fixed.h" | 26 #include "net/proxy/proxy_config_service_fixed.h" |
26 #include "net/proxy/proxy_resolver.h" | 27 #include "net/proxy/proxy_resolver.h" |
27 #include "net/proxy/proxy_service.h" | 28 #include "net/proxy/proxy_service.h" |
| 29 #include "net/quic/crypto/proof_verifier_chromium.h" |
28 #include "net/quic/crypto/quic_decrypter.h" | 30 #include "net/quic/crypto/quic_decrypter.h" |
29 #include "net/quic/crypto/quic_encrypter.h" | 31 #include "net/quic/crypto/quic_encrypter.h" |
30 #include "net/quic/quic_framer.h" | 32 #include "net/quic/quic_framer.h" |
31 #include "net/quic/quic_http_utils.h" | 33 #include "net/quic/quic_http_utils.h" |
32 #include "net/quic/test_tools/crypto_test_utils.h" | 34 #include "net/quic/test_tools/crypto_test_utils.h" |
33 #include "net/quic/test_tools/mock_clock.h" | 35 #include "net/quic/test_tools/mock_clock.h" |
34 #include "net/quic/test_tools/mock_crypto_client_stream_factory.h" | 36 #include "net/quic/test_tools/mock_crypto_client_stream_factory.h" |
35 #include "net/quic/test_tools/mock_random.h" | 37 #include "net/quic/test_tools/mock_random.h" |
36 #include "net/quic/test_tools/quic_test_packet_maker.h" | 38 #include "net/quic/test_tools/quic_test_packet_maker.h" |
37 #include "net/quic/test_tools/quic_test_utils.h" | 39 #include "net/quic/test_tools/quic_test_utils.h" |
38 #include "net/socket/client_socket_factory.h" | 40 #include "net/socket/client_socket_factory.h" |
39 #include "net/socket/mock_client_socket_pool_manager.h" | 41 #include "net/socket/mock_client_socket_pool_manager.h" |
40 #include "net/socket/socket_test_util.h" | 42 #include "net/socket/socket_test_util.h" |
41 #include "net/socket/ssl_client_socket.h" | 43 #include "net/socket/ssl_client_socket.h" |
42 #include "net/spdy/spdy_frame_builder.h" | 44 #include "net/spdy/spdy_frame_builder.h" |
43 #include "net/spdy/spdy_framer.h" | 45 #include "net/spdy/spdy_framer.h" |
44 #include "net/ssl/ssl_config_service_defaults.h" | 46 #include "net/ssl/ssl_config_service_defaults.h" |
| 47 #include "net/test/cert_test_util.h" |
45 #include "testing/gtest/include/gtest/gtest.h" | 48 #include "testing/gtest/include/gtest/gtest.h" |
46 #include "testing/platform_test.h" | 49 #include "testing/platform_test.h" |
47 | 50 |
48 //----------------------------------------------------------------------------- | 51 namespace net { |
| 52 namespace test { |
49 | 53 |
50 namespace { | 54 namespace { |
51 | 55 |
52 // This is the expected return from a current server advertising QUIC. | 56 // This is the expected return from a current server advertising QUIC. |
53 static const char kQuicAlternateProtocolHttpHeader[] = | 57 static const char kQuicAlternateProtocolHttpHeader[] = |
54 "Alternate-Protocol: 80:quic\r\n\r\n"; | 58 "Alternate-Protocol: 80:quic\r\n\r\n"; |
55 static const char kQuicAlternateProtocol50pctHttpHeader[] = | 59 static const char kQuicAlternateProtocol50pctHttpHeader[] = |
56 "Alternate-Protocol: 80:quic,p=.5\r\n\r\n"; | 60 "Alternate-Protocol: 80:quic,p=.5\r\n\r\n"; |
57 static const char kQuicAlternateProtocolDifferentPortHttpHeader[] = | 61 static const char kQuicAlternateProtocolDifferentPortHttpHeader[] = |
58 "Alternate-Protocol: 137:quic\r\n\r\n"; | 62 "Alternate-Protocol: 137:quic\r\n\r\n"; |
59 static const char kQuicAlternateProtocolHttpsHeader[] = | 63 static const char kQuicAlternateProtocolHttpsHeader[] = |
60 "Alternate-Protocol: 443:quic\r\n\r\n"; | 64 "Alternate-Protocol: 443:quic\r\n\r\n"; |
61 | 65 |
62 } // namespace | 66 } // namespace |
63 | 67 |
64 namespace net { | |
65 namespace test { | |
66 | |
67 // Helper class to encapsulate MockReads and MockWrites for QUIC. | 68 // Helper class to encapsulate MockReads and MockWrites for QUIC. |
68 // Simplify ownership issues and the interaction with the MockSocketFactory. | 69 // Simplify ownership issues and the interaction with the MockSocketFactory. |
69 class MockQuicData { | 70 class MockQuicData { |
70 public: | 71 public: |
71 MockQuicData() : sequence_number_(0) {} | 72 MockQuicData() : sequence_number_(0) {} |
72 | 73 |
73 ~MockQuicData() { | 74 ~MockQuicData() { |
74 STLDeleteElements(&packets_); | 75 STLDeleteElements(&packets_); |
75 } | 76 } |
76 | 77 |
(...skipping 1116 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1193 &address, | 1194 &address, |
1194 CompletionCallback(), | 1195 CompletionCallback(), |
1195 nullptr, | 1196 nullptr, |
1196 net_log_.bound()); | 1197 net_log_.bound()); |
1197 | 1198 |
1198 CreateSessionWithNextProtos(); | 1199 CreateSessionWithNextProtos(); |
1199 AddQuicAlternateProtocolMapping(MockCryptoClientStream::ZERO_RTT); | 1200 AddQuicAlternateProtocolMapping(MockCryptoClientStream::ZERO_RTT); |
1200 SendRequestAndExpectHttpResponse("hello world"); | 1201 SendRequestAndExpectHttpResponse("hello world"); |
1201 } | 1202 } |
1202 | 1203 |
| 1204 // Test that a secure request over an insecure QUIC connection fails with |
| 1205 // the appropriate error code. Note that this never happens in production, |
| 1206 // because the handshake (which this test mocks) would fail in this scenario. |
| 1207 TEST_P(QuicNetworkTransactionTest, SecureResourceOverInsecureQuic) { |
| 1208 MockQuicData mock_quic_data; |
| 1209 mock_quic_data.AddWrite( |
| 1210 ConstructRequestHeadersPacket(1, kClientDataStreamId1, true, true, |
| 1211 GetRequestHeaders("GET", "https", "/"))); |
| 1212 mock_quic_data.AddRead(ConstructResponseHeadersPacket( |
| 1213 1, kClientDataStreamId1, false, false, GetResponseHeaders("200 OK"))); |
| 1214 mock_quic_data.AddRead( |
| 1215 ConstructDataPacket(2, kClientDataStreamId1, false, true, 0, "hello!")); |
| 1216 mock_quic_data.AddWrite(ConstructAckPacket(2, 1)); |
| 1217 mock_quic_data.AddRead(SYNCHRONOUS, 0); |
| 1218 mock_quic_data.AddSocketDataToFactory(&socket_factory_); |
| 1219 |
| 1220 request_.url = GURL("https://www.google.com:443"); |
| 1221 AddHangingNonAlternateProtocolSocketData(); |
| 1222 CreateSessionWithNextProtos(); |
| 1223 AddQuicAlternateProtocolMapping(MockCryptoClientStream::CONFIRM_HANDSHAKE); |
| 1224 scoped_ptr<HttpNetworkTransaction> trans( |
| 1225 new HttpNetworkTransaction(DEFAULT_PRIORITY, session_.get())); |
| 1226 TestCompletionCallback callback; |
| 1227 int rv = trans->Start(&request_, callback.callback(), net_log_.bound()); |
| 1228 EXPECT_EQ(ERR_REQUEST_FOR_SECURE_RESOURCE_OVER_INSECURE_QUIC, |
| 1229 callback.GetResult(rv)); |
| 1230 } |
| 1231 |
| 1232 TEST_P(QuicNetworkTransactionTest, SecureResourceOverSecureQuic) { |
| 1233 MockQuicData mock_quic_data; |
| 1234 mock_quic_data.AddWrite( |
| 1235 ConstructRequestHeadersPacket(1, kClientDataStreamId1, true, true, |
| 1236 GetRequestHeaders("GET", "https", "/"))); |
| 1237 mock_quic_data.AddRead(ConstructResponseHeadersPacket( |
| 1238 1, kClientDataStreamId1, false, false, GetResponseHeaders("200 OK"))); |
| 1239 mock_quic_data.AddRead( |
| 1240 ConstructDataPacket(2, kClientDataStreamId1, false, true, 0, "hello!")); |
| 1241 mock_quic_data.AddWrite(ConstructAckPacket(2, 1)); |
| 1242 mock_quic_data.AddRead(SYNCHRONOUS, 0); |
| 1243 mock_quic_data.AddSocketDataToFactory(&socket_factory_); |
| 1244 |
| 1245 scoped_refptr<X509Certificate> cert( |
| 1246 ImportCertFromFile(GetTestCertsDirectory(), "spdy_pooling.pem")); |
| 1247 ASSERT_TRUE(cert.get()); |
| 1248 ProofVerifyDetailsChromium verify_details; |
| 1249 verify_details.cert_verify_result.verified_cert = cert; |
| 1250 crypto_client_stream_factory_.set_proof_verify_details(&verify_details); |
| 1251 |
| 1252 request_.url = GURL("https://www.google.com:443"); |
| 1253 AddHangingNonAlternateProtocolSocketData(); |
| 1254 CreateSessionWithNextProtos(); |
| 1255 AddQuicAlternateProtocolMapping(MockCryptoClientStream::CONFIRM_HANDSHAKE); |
| 1256 SendRequestAndExpectQuicResponse("hello!"); |
| 1257 } |
| 1258 |
1203 } // namespace test | 1259 } // namespace test |
1204 } // namespace net | 1260 } // namespace net |
OLD | NEW |