Chromium Code Reviews| 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 |