[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 1 | // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 5 | #include <ostream> |
dcheng | c7eeda42 | 2015-12-26 03:56:48 | [diff] [blame] | 6 | #include <utility> |
olli.raula | 6df48b2a | 2015-11-26 07:40:22 | [diff] [blame] | 7 | #include <vector> |
| 8 | |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 9 | #include "base/compiler_specific.h" |
| 10 | #include "base/memory/scoped_ptr.h" |
| 11 | #include "base/stl_util.h" |
| 12 | #include "base/strings/string_number_conversions.h" |
mmenke | cbc2b71 | 2014-10-09 20:29:07 | [diff] [blame] | 13 | #include "net/base/elements_upload_data_stream.h" |
martijn | cc5402d | 2016-02-16 19:08:58 | [diff] [blame] | 14 | #include "net/base/ip_address.h" |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 15 | #include "net/base/test_completion_callback.h" |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 16 | #include "net/base/test_data_directory.h" |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 17 | #include "net/base/upload_bytes_element_reader.h" |
| 18 | #include "net/base/upload_data_stream.h" |
| 19 | #include "net/cert/mock_cert_verifier.h" |
rtenneti | 052774e | 2015-11-24 21:00:12 | [diff] [blame] | 20 | #include "net/cert/multi_log_ct_verifier.h" |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 21 | #include "net/dns/mapped_host_resolver.h" |
| 22 | #include "net/dns/mock_host_resolver.h" |
| 23 | #include "net/http/http_auth_handler_factory.h" |
| 24 | #include "net/http/http_network_session.h" |
| 25 | #include "net/http/http_network_transaction.h" |
| 26 | #include "net/http/http_server_properties_impl.h" |
[email protected] | c41737d | 2014-05-14 07:47:19 | [diff] [blame] | 27 | #include "net/http/http_transaction_test_util.h" |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 28 | #include "net/http/transport_security_state.h" |
| 29 | #include "net/proxy/proxy_service.h" |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 30 | #include "net/quic/test_tools/crypto_test_utils.h" |
[email protected] | 9bb57c7 | 2014-03-31 20:36:04 | [diff] [blame] | 31 | #include "net/quic/test_tools/quic_test_utils.h" |
nharper | d5cddca | 2016-02-27 03:37:52 | [diff] [blame] | 32 | #include "net/ssl/default_channel_id_store.h" |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 33 | #include "net/ssl/ssl_config_service_defaults.h" |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 34 | #include "net/test/cert_test_util.h" |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 35 | #include "net/tools/quic/quic_in_memory_cache.h" |
[email protected] | a5b9817 | 2014-06-18 07:01:59 | [diff] [blame] | 36 | #include "net/tools/quic/quic_server.h" |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 37 | #include "net/tools/quic/test_tools/quic_in_memory_cache_peer.h" |
| 38 | #include "net/tools/quic/test_tools/server_thread.h" |
| 39 | #include "testing/gtest/include/gtest/gtest.h" |
| 40 | #include "testing/platform_test.h" |
| 41 | |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 42 | using base::StringPiece; |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 43 | |
| 44 | namespace net { |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 45 | |
rch | 750447f9 | 2016-01-31 02:54:53 | [diff] [blame] | 46 | using test::QuicInMemoryCachePeer; |
| 47 | using test::ServerThread; |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 48 | |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 49 | namespace test { |
| 50 | |
| 51 | namespace { |
| 52 | |
| 53 | const char kResponseBody[] = "some arbitrary response body"; |
| 54 | |
| 55 | // Factory for creating HttpTransactions, used by TestTransactionConsumer. |
| 56 | class TestTransactionFactory : public HttpTransactionFactory { |
| 57 | public: |
mmenke | e65e7af | 2015-10-13 17:16:42 | [diff] [blame] | 58 | explicit TestTransactionFactory(const HttpNetworkSession::Params& params) |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 59 | : session_(new HttpNetworkSession(params)) {} |
| 60 | |
dcheng | 67be2b1f | 2014-10-27 21:47:29 | [diff] [blame] | 61 | ~TestTransactionFactory() override {} |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 62 | |
| 63 | // HttpTransactionFactory methods |
dcheng | 67be2b1f | 2014-10-27 21:47:29 | [diff] [blame] | 64 | int CreateTransaction(RequestPriority priority, |
| 65 | scoped_ptr<HttpTransaction>* trans) override { |
dcheng | 4227c6d | 2014-08-25 23:58:18 | [diff] [blame] | 66 | trans->reset(new HttpNetworkTransaction(priority, session_.get())); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 67 | return OK; |
| 68 | } |
| 69 | |
dcheng | 67be2b1f | 2014-10-27 21:47:29 | [diff] [blame] | 70 | HttpCache* GetCache() override { return nullptr; } |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 71 | |
dcheng | 67be2b1f | 2014-10-27 21:47:29 | [diff] [blame] | 72 | HttpNetworkSession* GetSession() override { return session_.get(); }; |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 73 | |
| 74 | private: |
mmenke | e65e7af | 2015-10-13 17:16:42 | [diff] [blame] | 75 | scoped_ptr<HttpNetworkSession> session_; |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 76 | }; |
| 77 | |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 78 | struct TestParams { |
| 79 | explicit TestParams(bool use_stateless_rejects) |
| 80 | : use_stateless_rejects(use_stateless_rejects) {} |
| 81 | |
| 82 | friend std::ostream& operator<<(std::ostream& os, const TestParams& p) { |
| 83 | os << "{ use_stateless_rejects: " << p.use_stateless_rejects << " }"; |
| 84 | return os; |
| 85 | } |
| 86 | bool use_stateless_rejects; |
| 87 | }; |
| 88 | |
| 89 | std::vector<TestParams> GetTestParams() { |
| 90 | return std::vector<TestParams>{TestParams(true), TestParams(false)}; |
| 91 | } |
| 92 | |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 93 | } // namespace |
| 94 | |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 95 | class QuicEndToEndTest : public ::testing::TestWithParam<TestParams> { |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 96 | protected: |
| 97 | QuicEndToEndTest() |
| 98 | : host_resolver_impl_(CreateResolverImpl()), |
dcheng | c7eeda42 | 2015-12-26 03:56:48 | [diff] [blame] | 99 | host_resolver_(std::move(host_resolver_impl_)), |
rtenneti | 052774e | 2015-11-24 21:00:12 | [diff] [blame] | 100 | cert_transparency_verifier_(new MultiLogCTVerifier()), |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 101 | ssl_config_service_(new SSLConfigServiceDefaults), |
| 102 | proxy_service_(ProxyService::CreateDirect()), |
| 103 | auth_handler_factory_( |
[email protected] | d4adc30 | 2013-09-30 03:02:34 | [diff] [blame] | 104 | HttpAuthHandlerFactory::CreateDefault(&host_resolver_)), |
| 105 | strike_register_no_startup_period_(false) { |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 106 | request_.method = "GET"; |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 107 | request_.url = GURL("https://test.example.com/"); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 108 | request_.load_flags = 0; |
| 109 | |
| 110 | params_.enable_quic = true; |
rtenneti | be63573 | 2014-10-02 22:51:42 | [diff] [blame] | 111 | params_.quic_clock = nullptr; |
| 112 | params_.quic_random = nullptr; |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 113 | if (GetParam().use_stateless_rejects) { |
| 114 | params_.quic_connection_options.push_back(kSREJ); |
| 115 | } |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 116 | params_.host_resolver = &host_resolver_; |
| 117 | params_.cert_verifier = &cert_verifier_; |
| 118 | params_.transport_security_state = &transport_security_state_; |
rtenneti | 052774e | 2015-11-24 21:00:12 | [diff] [blame] | 119 | params_.cert_transparency_verifier = cert_transparency_verifier_.get(); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 120 | params_.proxy_service = proxy_service_.get(); |
| 121 | params_.ssl_config_service = ssl_config_service_.get(); |
| 122 | params_.http_auth_handler_factory = auth_handler_factory_.get(); |
| 123 | params_.http_server_properties = http_server_properties.GetWeakPtr(); |
nharper | d5cddca | 2016-02-27 03:37:52 | [diff] [blame] | 124 | channel_id_service_.reset( |
| 125 | new ChannelIDService(new DefaultChannelIDStore(nullptr), |
| 126 | base::ThreadTaskRunnerHandle::Get())); |
| 127 | params_.channel_id_service = channel_id_service_.get(); |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 128 | |
tfarina | a3dd7aa | 2016-02-25 08:15:44 | [diff] [blame] | 129 | CertVerifyResult verify_result; |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 130 | verify_result.verified_cert = ImportCertFromFile( |
| 131 | GetTestCertsDirectory(), "quic_test.example.com.crt"); |
| 132 | cert_verifier_.AddResultForCertAndHost(verify_result.verified_cert.get(), |
| 133 | "test.example.com", verify_result, |
| 134 | OK); |
| 135 | verify_result.verified_cert = ImportCertFromFile( |
| 136 | GetTestCertsDirectory(), "quic_test_ecc.example.com.crt"); |
| 137 | cert_verifier_.AddResultForCertAndHost(verify_result.verified_cert.get(), |
| 138 | "test.example.com", verify_result, |
| 139 | OK); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 140 | } |
| 141 | |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 142 | // Creates a mock host resolver in which test.example.com |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 143 | // resolves to localhost. |
| 144 | static MockHostResolver* CreateResolverImpl() { |
| 145 | MockHostResolver* resolver = new MockHostResolver(); |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 146 | resolver->rules()->AddRule("test.example.com", "127.0.0.1"); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 147 | return resolver; |
| 148 | } |
| 149 | |
dcheng | 67be2b1f | 2014-10-27 21:47:29 | [diff] [blame] | 150 | void SetUp() override { |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 151 | QuicInMemoryCachePeer::ResetForTests(); |
| 152 | StartServer(); |
| 153 | |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 154 | // Use a mapped host resolver so that request for test.example.com (port 80) |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 155 | // reach the server running on localhost. |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 156 | std::string map_rule = "MAP test.example.com test.example.com:" + |
| 157 | base::IntToString(server_thread_->GetPort()); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 158 | EXPECT_TRUE(host_resolver_.AddRuleFromString(map_rule)); |
| 159 | |
| 160 | // To simplify the test, and avoid the race with the HTTP request, we force |
| 161 | // QUIC for these requests. |
rtenneti | 8a2f463 | 2016-03-21 20:26:57 | [diff] [blame^] | 162 | params_.origins_to_force_quic_on.insert( |
| 163 | HostPortPair::FromString("test.example.com:443")); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 164 | |
| 165 | transaction_factory_.reset(new TestTransactionFactory(params_)); |
| 166 | } |
| 167 | |
dcheng | 67be2b1f | 2014-10-27 21:47:29 | [diff] [blame] | 168 | void TearDown() override { |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 169 | StopServer(); |
| 170 | QuicInMemoryCachePeer::ResetForTests(); |
| 171 | } |
| 172 | |
| 173 | // Starts the QUIC server listening on a random port. |
| 174 | void StartServer() { |
tfarina | a3dd7aa | 2016-02-25 08:15:44 | [diff] [blame] | 175 | server_address_ = IPEndPoint(IPAddress(127, 0, 0, 1), 0); |
[email protected] | 7d56135 | 2014-06-20 09:09:21 | [diff] [blame] | 176 | server_config_.SetInitialStreamFlowControlWindowToSend( |
| 177 | kInitialStreamFlowControlWindowForTest); |
| 178 | server_config_.SetInitialSessionFlowControlWindowToSend( |
| 179 | kInitialSessionFlowControlWindowForTest); |
nharper | d5cddca | 2016-02-27 03:37:52 | [diff] [blame] | 180 | server_config_options_.token_binding_enabled = true; |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 181 | QuicServer* server = |
rch | 1fe2eeb | 2015-10-26 14:45:57 | [diff] [blame] | 182 | new QuicServer(CryptoTestUtils::ProofSourceForTesting(), server_config_, |
nharper | d5cddca | 2016-02-27 03:37:52 | [diff] [blame] | 183 | server_config_options_, QuicSupportedVersions()); |
rch | 1fe2eeb | 2015-10-26 14:45:57 | [diff] [blame] | 184 | server_thread_.reset(new ServerThread(server, server_address_, |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 185 | strike_register_no_startup_period_)); |
[email protected] | 8c2cfd6 | 2014-01-09 19:13:03 | [diff] [blame] | 186 | server_thread_->Initialize(); |
rjshade | d5ced07 | 2015-12-18 19:26:02 | [diff] [blame] | 187 | server_address_ = |
| 188 | IPEndPoint(server_address_.address(), server_thread_->GetPort()); |
[email protected] | 8c2cfd6 | 2014-01-09 19:13:03 | [diff] [blame] | 189 | server_thread_->Start(); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 190 | server_started_ = true; |
| 191 | } |
| 192 | |
| 193 | // Stops the QUIC server. |
| 194 | void StopServer() { |
| 195 | if (!server_started_) { |
| 196 | return; |
| 197 | } |
| 198 | if (server_thread_.get()) { |
[email protected] | 98f49e4 | 2013-11-08 19:30:57 | [diff] [blame] | 199 | server_thread_->Quit(); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 200 | server_thread_->Join(); |
| 201 | } |
| 202 | } |
| 203 | |
| 204 | // Adds an entry to the cache used by the QUIC server to serve |
| 205 | // responses. |
rch | aa7859a1 | 2015-03-23 22:50:08 | [diff] [blame] | 206 | void AddToCache(StringPiece path, |
| 207 | int response_code, |
| 208 | StringPiece response_detail, |
| 209 | StringPiece body) { |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 210 | QuicInMemoryCache::GetInstance()->AddSimpleResponse( |
rtenneti | c82ee4e3 | 2015-11-11 04:32:34 | [diff] [blame] | 211 | "test.example.com", path, response_code, body); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 212 | } |
| 213 | |
| 214 | // Populates |request_body_| with |length_| ASCII bytes. |
| 215 | void GenerateBody(size_t length) { |
| 216 | request_body_.clear(); |
| 217 | request_body_.reserve(length); |
| 218 | for (size_t i = 0; i < length; ++i) { |
| 219 | request_body_.append(1, static_cast<char>(32 + i % (126 - 32))); |
| 220 | } |
| 221 | } |
| 222 | |
| 223 | // Initializes |request_| for a post of |length| bytes. |
| 224 | void InitializePostRequest(size_t length) { |
| 225 | GenerateBody(length); |
olli.raula | 6df48b2a | 2015-11-26 07:40:22 | [diff] [blame] | 226 | std::vector<scoped_ptr<UploadElementReader>> element_readers; |
| 227 | element_readers.push_back(make_scoped_ptr(new UploadBytesElementReader( |
| 228 | request_body_.data(), request_body_.length()))); |
mmenke | cbc2b71 | 2014-10-09 20:29:07 | [diff] [blame] | 229 | upload_data_stream_.reset( |
olli.raula | 6df48b2a | 2015-11-26 07:40:22 | [diff] [blame] | 230 | new ElementsUploadDataStream(std::move(element_readers), 0)); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 231 | request_.method = "POST"; |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 232 | request_.url = GURL("https://test.example.com/"); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 233 | request_.upload_data_stream = upload_data_stream_.get(); |
| 234 | ASSERT_EQ(OK, request_.upload_data_stream->Init(CompletionCallback())); |
| 235 | } |
| 236 | |
| 237 | // Checks that |consumer| completed and received |status_line| and |body|. |
| 238 | void CheckResponse(const TestTransactionConsumer& consumer, |
| 239 | const std::string& status_line, |
| 240 | const std::string& body) { |
| 241 | ASSERT_TRUE(consumer.is_done()); |
rch | f114d98 | 2015-10-21 01:34:56 | [diff] [blame] | 242 | ASSERT_EQ(OK, consumer.error()); |
rjshade | d5ced07 | 2015-12-18 19:26:02 | [diff] [blame] | 243 | EXPECT_EQ(status_line, consumer.response_info()->headers->GetStatusLine()); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 244 | EXPECT_EQ(body, consumer.content()); |
| 245 | } |
| 246 | |
| 247 | scoped_ptr<MockHostResolver> host_resolver_impl_; |
| 248 | MappedHostResolver host_resolver_; |
| 249 | MockCertVerifier cert_verifier_; |
nharper | d5cddca | 2016-02-27 03:37:52 | [diff] [blame] | 250 | scoped_ptr<ChannelIDService> channel_id_service_; |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 251 | TransportSecurityState transport_security_state_; |
rtenneti | 052774e | 2015-11-24 21:00:12 | [diff] [blame] | 252 | scoped_ptr<CTVerifier> cert_transparency_verifier_; |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 253 | scoped_refptr<SSLConfigServiceDefaults> ssl_config_service_; |
| 254 | scoped_ptr<ProxyService> proxy_service_; |
| 255 | scoped_ptr<HttpAuthHandlerFactory> auth_handler_factory_; |
| 256 | HttpServerPropertiesImpl http_server_properties; |
| 257 | HttpNetworkSession::Params params_; |
| 258 | scoped_ptr<TestTransactionFactory> transaction_factory_; |
| 259 | HttpRequestInfo request_; |
| 260 | std::string request_body_; |
| 261 | scoped_ptr<UploadDataStream> upload_data_stream_; |
| 262 | scoped_ptr<ServerThread> server_thread_; |
| 263 | IPEndPoint server_address_; |
| 264 | std::string server_hostname_; |
| 265 | QuicConfig server_config_; |
nharper | d5cddca | 2016-02-27 03:37:52 | [diff] [blame] | 266 | QuicCryptoServerConfig::ConfigOptions server_config_options_; |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 267 | bool server_started_; |
| 268 | bool strike_register_no_startup_period_; |
| 269 | }; |
| 270 | |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 271 | INSTANTIATE_TEST_CASE_P(Tests, |
| 272 | QuicEndToEndTest, |
| 273 | ::testing::ValuesIn(GetTestParams())); |
| 274 | |
| 275 | TEST_P(QuicEndToEndTest, LargeGetWithNoPacketLoss) { |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 276 | std::string response(10 * 1024, 'x'); |
| 277 | |
rch | aa7859a1 | 2015-03-23 22:50:08 | [diff] [blame] | 278 | AddToCache(request_.url.PathForRequest(), 200, "OK", response); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 279 | |
| 280 | TestTransactionConsumer consumer(DEFAULT_PRIORITY, |
| 281 | transaction_factory_.get()); |
| 282 | consumer.Start(&request_, BoundNetLog()); |
| 283 | |
| 284 | // Will terminate when the last consumer completes. |
| 285 | base::MessageLoop::current()->Run(); |
| 286 | |
bnc | 84e7fb5 | 2015-12-02 11:50:02 | [diff] [blame] | 287 | CheckResponse(consumer, "HTTP/1.1 200", response); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 288 | } |
| 289 | |
nharper | d5cddca | 2016-02-27 03:37:52 | [diff] [blame] | 290 | TEST_P(QuicEndToEndTest, TokenBinding) { |
| 291 | // Enable token binding and re-initialize the TestTransactionFactory. |
| 292 | params_.enable_token_binding = true; |
| 293 | transaction_factory_.reset(new TestTransactionFactory(params_)); |
| 294 | |
| 295 | AddToCache(request_.url.PathForRequest(), 200, "OK", kResponseBody); |
| 296 | |
| 297 | TestTransactionConsumer consumer(DEFAULT_PRIORITY, |
| 298 | transaction_factory_.get()); |
| 299 | consumer.Start(&request_, BoundNetLog()); |
| 300 | |
| 301 | // Will terminate when the last consumer completes. |
| 302 | base::MessageLoop::current()->Run(); |
| 303 | |
| 304 | CheckResponse(consumer, "HTTP/1.1 200", kResponseBody); |
| 305 | HttpRequestHeaders headers; |
| 306 | ASSERT_TRUE(consumer.transaction()->GetFullRequestHeaders(&headers)); |
| 307 | EXPECT_TRUE(headers.HasHeader(HttpRequestHeaders::kTokenBinding)); |
| 308 | } |
| 309 | |
rtenneti | e3b666d | 2016-01-08 05:07:28 | [diff] [blame] | 310 | // crbug.com/559173 |
| 311 | #if defined(THREAD_SANITIZER) |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 312 | TEST_P(QuicEndToEndTest, DISABLED_LargePostWithNoPacketLoss) { |
rtenneti | e3b666d | 2016-01-08 05:07:28 | [diff] [blame] | 313 | #else |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 314 | TEST_P(QuicEndToEndTest, LargePostWithNoPacketLoss) { |
rtenneti | e3b666d | 2016-01-08 05:07:28 | [diff] [blame] | 315 | #endif |
rtenneti | 97238d66 | 2015-10-23 16:16:58 | [diff] [blame] | 316 | InitializePostRequest(1024 * 1024); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 317 | |
rch | aa7859a1 | 2015-03-23 22:50:08 | [diff] [blame] | 318 | AddToCache(request_.url.PathForRequest(), 200, "OK", kResponseBody); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 319 | |
| 320 | TestTransactionConsumer consumer(DEFAULT_PRIORITY, |
| 321 | transaction_factory_.get()); |
| 322 | consumer.Start(&request_, BoundNetLog()); |
| 323 | |
| 324 | // Will terminate when the last consumer completes. |
| 325 | base::MessageLoop::current()->Run(); |
| 326 | |
bnc | 84e7fb5 | 2015-12-02 11:50:02 | [diff] [blame] | 327 | CheckResponse(consumer, "HTTP/1.1 200", kResponseBody); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 328 | } |
| 329 | |
rtenneti | e3b666d | 2016-01-08 05:07:28 | [diff] [blame] | 330 | // crbug.com/559173 |
| 331 | #if defined(THREAD_SANITIZER) |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 332 | TEST_P(QuicEndToEndTest, DISABLED_LargePostWithPacketLoss) { |
rtenneti | e3b666d | 2016-01-08 05:07:28 | [diff] [blame] | 333 | #else |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 334 | TEST_P(QuicEndToEndTest, LargePostWithPacketLoss) { |
rtenneti | e3b666d | 2016-01-08 05:07:28 | [diff] [blame] | 335 | #endif |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 336 | // FLAGS_fake_packet_loss_percentage = 30; |
| 337 | InitializePostRequest(1024 * 1024); |
| 338 | |
| 339 | const char kResponseBody[] = "some really big response body"; |
rch | aa7859a1 | 2015-03-23 22:50:08 | [diff] [blame] | 340 | AddToCache(request_.url.PathForRequest(), 200, "OK", kResponseBody); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 341 | |
| 342 | TestTransactionConsumer consumer(DEFAULT_PRIORITY, |
| 343 | transaction_factory_.get()); |
| 344 | consumer.Start(&request_, BoundNetLog()); |
| 345 | |
| 346 | // Will terminate when the last consumer completes. |
| 347 | base::MessageLoop::current()->Run(); |
| 348 | |
bnc | 84e7fb5 | 2015-12-02 11:50:02 | [diff] [blame] | 349 | CheckResponse(consumer, "HTTP/1.1 200", kResponseBody); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 350 | } |
| 351 | |
zhaoqin | f60fa49 | 2015-09-30 16:24:08 | [diff] [blame] | 352 | // crbug.com/536845 |
| 353 | #if defined(THREAD_SANITIZER) |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 354 | TEST_P(QuicEndToEndTest, DISABLED_UberTest) { |
zhaoqin | f60fa49 | 2015-09-30 16:24:08 | [diff] [blame] | 355 | #else |
rch | f37ccc78 | 2016-01-31 05:13:50 | [diff] [blame] | 356 | TEST_P(QuicEndToEndTest, UberTest) { |
zhaoqin | f60fa49 | 2015-09-30 16:24:08 | [diff] [blame] | 357 | #endif |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 358 | // FLAGS_fake_packet_loss_percentage = 30; |
| 359 | |
| 360 | const char kResponseBody[] = "some really big response body"; |
rch | aa7859a1 | 2015-03-23 22:50:08 | [diff] [blame] | 361 | AddToCache(request_.url.PathForRequest(), 200, "OK", kResponseBody); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 362 | |
| 363 | std::vector<TestTransactionConsumer*> consumers; |
| 364 | size_t num_requests = 100; |
| 365 | for (size_t i = 0; i < num_requests; ++i) { |
rjshade | d5ced07 | 2015-12-18 19:26:02 | [diff] [blame] | 366 | TestTransactionConsumer* consumer = new TestTransactionConsumer( |
| 367 | DEFAULT_PRIORITY, transaction_factory_.get()); |
| 368 | consumers.push_back(consumer); |
| 369 | consumer->Start(&request_, BoundNetLog()); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 370 | } |
| 371 | |
| 372 | // Will terminate when the last consumer completes. |
| 373 | base::MessageLoop::current()->Run(); |
| 374 | |
| 375 | for (size_t i = 0; i < num_requests; ++i) { |
bnc | 84e7fb5 | 2015-12-02 11:50:02 | [diff] [blame] | 376 | CheckResponse(*consumers[i], "HTTP/1.1 200", kResponseBody); |
[email protected] | 50ca73e2 | 2013-09-30 00:37:50 | [diff] [blame] | 377 | } |
| 378 | STLDeleteElements(&consumers); |
| 379 | } |
| 380 | |
| 381 | } // namespace test |
| 382 | } // namespace net |