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_P(QuicNetworkTransactionTest, SecureResourceOverInsecureQuic) { | |
1205 MockQuicData mock_quic_data; | |
1206 mock_quic_data.AddWrite( | |
1207 ConstructRequestHeadersPacket(1, kClientDataStreamId1, true, true, | |
1208 GetRequestHeaders("GET", "https", "/"))); | |
1209 mock_quic_data.AddRead(ConstructResponseHeadersPacket( | |
1210 1, kClientDataStreamId1, false, false, GetResponseHeaders("200 OK"))); | |
1211 mock_quic_data.AddRead( | |
1212 ConstructDataPacket(2, kClientDataStreamId1, false, true, 0, "hello!")); | |
1213 mock_quic_data.AddWrite(ConstructAckPacket(2, 1)); | |
1214 mock_quic_data.AddRead(SYNCHRONOUS, 0); | |
1215 mock_quic_data.AddSocketDataToFactory(&socket_factory_); | |
1216 | |
1217 request_.url = GURL("https://www.google.com:443"); | |
1218 AddHangingNonAlternateProtocolSocketData(); | |
1219 CreateSessionWithNextProtos(); | |
1220 AddQuicAlternateProtocolMapping(MockCryptoClientStream::CONFIRM_HANDSHAKE); | |
1221 scoped_ptr<HttpNetworkTransaction> trans( | |
1222 new HttpNetworkTransaction(DEFAULT_PRIORITY, session_.get())); | |
1223 TestCompletionCallback callback; | |
1224 int rv = trans->Start(&request_, callback.callback(), net_log_.bound()); | |
1225 EXPECT_EQ(ERR_REQUEST_FOR_SECURE_RESOURCE_OVER_INSECURE_QUIC, | |
1226 callback.GetResult(rv)); | |
1227 } | |
Ryan Hamilton
2015/05/12 18:15:56
Hm. This is actually unreachable in reality, right
Bence
2015/05/12 19:51:56
Done.
| |
1228 | |
1229 TEST_P(QuicNetworkTransactionTest, SecureResourceOverSecureQuic) { | |
1230 MockQuicData mock_quic_data; | |
1231 mock_quic_data.AddWrite( | |
1232 ConstructRequestHeadersPacket(1, kClientDataStreamId1, true, true, | |
1233 GetRequestHeaders("GET", "https", "/"))); | |
1234 mock_quic_data.AddRead(ConstructResponseHeadersPacket( | |
1235 1, kClientDataStreamId1, false, false, GetResponseHeaders("200 OK"))); | |
1236 mock_quic_data.AddRead( | |
1237 ConstructDataPacket(2, kClientDataStreamId1, false, true, 0, "hello!")); | |
1238 mock_quic_data.AddWrite(ConstructAckPacket(2, 1)); | |
1239 mock_quic_data.AddRead(SYNCHRONOUS, 0); | |
1240 mock_quic_data.AddSocketDataToFactory(&socket_factory_); | |
1241 | |
1242 scoped_refptr<X509Certificate> cert( | |
1243 ImportCertFromFile(GetTestCertsDirectory(), "spdy_pooling.pem")); | |
1244 ASSERT_TRUE(cert.get()); | |
1245 ProofVerifyDetailsChromium verify_details; | |
1246 verify_details.cert_verify_result.verified_cert = cert; | |
1247 crypto_client_stream_factory_.set_proof_verify_details(&verify_details); | |
1248 | |
1249 request_.url = GURL("https://www.google.com:443"); | |
1250 AddHangingNonAlternateProtocolSocketData(); | |
1251 CreateSessionWithNextProtos(); | |
1252 AddQuicAlternateProtocolMapping(MockCryptoClientStream::CONFIRM_HANDSHAKE); | |
1253 SendRequestAndExpectQuicResponse("hello!"); | |
1254 } | |
1255 | |
1203 } // namespace test | 1256 } // namespace test |
1204 } // namespace net | 1257 } // namespace net |
OLD | NEW |