Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(13)

Side by Side Diff: net/spdy/spdy_http_stream_spdy3_unittest.cc

Issue 9582034: Fork SPDY/2 and SPDY/3 versions of our SPDY tests, in preparation for landing (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Fix merge bug Created 8 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « net/spdy/spdy_http_stream_spdy2_unittest.cc ('k') | net/spdy/spdy_http_stream_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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/spdy/spdy_http_stream.h" 5 #include "net/spdy/spdy_http_stream.h"
6 6
7 #include "crypto/ec_private_key.h" 7 #include "crypto/ec_private_key.h"
8 #include "crypto/ec_signature_creator.h" 8 #include "crypto/ec_signature_creator.h"
9 #include "crypto/signature_creator.h" 9 #include "crypto/signature_creator.h"
10 #include "net/base/asn1_util.h" 10 #include "net/base/asn1_util.h"
11 #include "net/base/default_origin_bound_cert_store.h" 11 #include "net/base/default_origin_bound_cert_store.h"
12 #include "net/http/http_response_headers.h" 12 #include "net/http/http_response_headers.h"
13 #include "net/http/http_response_info.h" 13 #include "net/http/http_response_info.h"
14 #include "net/spdy/spdy_session.h" 14 #include "net/spdy/spdy_session.h"
15 #include "net/spdy/spdy_test_util.h" 15 #include "net/spdy/spdy_test_util_spdy3.h"
16 #include "testing/gtest/include/gtest/gtest.h" 16 #include "testing/gtest/include/gtest/gtest.h"
17 17
18 using namespace net::test_spdy3;
19
18 namespace net { 20 namespace net {
19 21
20 class SpdyHttpStreamTest : public testing::Test { 22 class SpdyHttpStreamSpdy3Test : public testing::Test {
21 public: 23 public:
22 OrderedSocketData* data() { return data_.get(); } 24 OrderedSocketData* data() { return data_.get(); }
23 protected: 25 protected:
24 SpdyHttpStreamTest() {} 26 SpdyHttpStreamSpdy3Test() {}
25 27
26 void EnableCompression(bool enabled) { 28 void EnableCompression(bool enabled) {
27 spdy::SpdyFramer::set_enable_compression_default(enabled); 29 spdy::SpdyFramer::set_enable_compression_default(enabled);
28 } 30 }
29 31
30 virtual void TearDown() { 32 virtual void TearDown() {
31 crypto::ECSignatureCreator::SetFactoryForTesting(NULL); 33 crypto::ECSignatureCreator::SetFactoryForTesting(NULL);
32 MessageLoop::current()->RunAllPending(); 34 MessageLoop::current()->RunAllPending();
33 } 35 }
34 int InitSession(MockRead* reads, size_t reads_count, 36 int InitSession(MockRead* reads, size_t reads_count,
(...skipping 26 matching lines...) Expand all
61 const std::string& proof, 63 const std::string& proof,
62 SSLClientCertType type); 64 SSLClientCertType type);
63 65
64 SpdySessionDependencies session_deps_; 66 SpdySessionDependencies session_deps_;
65 scoped_ptr<OrderedSocketData> data_; 67 scoped_ptr<OrderedSocketData> data_;
66 scoped_refptr<HttpNetworkSession> http_session_; 68 scoped_refptr<HttpNetworkSession> http_session_;
67 scoped_refptr<SpdySession> session_; 69 scoped_refptr<SpdySession> session_;
68 scoped_refptr<TransportSocketParams> transport_params_; 70 scoped_refptr<TransportSocketParams> transport_params_;
69 }; 71 };
70 72
71 TEST_F(SpdyHttpStreamTest, SendRequest) { 73 TEST_F(SpdyHttpStreamSpdy3Test, SendRequest) {
72 EnableCompression(false); 74 EnableCompression(false);
73 SpdySession::SetSSLMode(false); 75 SpdySession::SetSSLMode(false);
74 76
75 scoped_ptr<spdy::SpdyFrame> req(ConstructSpdyGet(NULL, 0, false, 1, LOWEST)); 77 scoped_ptr<spdy::SpdyFrame> req(ConstructSpdyGet(NULL, 0, false, 1, LOWEST));
76 MockWrite writes[] = { 78 MockWrite writes[] = {
77 CreateMockWrite(*req.get(), 1), 79 CreateMockWrite(*req.get(), 1),
78 }; 80 };
79 scoped_ptr<spdy::SpdyFrame> resp(ConstructSpdyGetSynReply(NULL, 0, 1)); 81 scoped_ptr<spdy::SpdyFrame> resp(ConstructSpdyGetSynReply(NULL, 0, 1));
80 MockRead reads[] = { 82 MockRead reads[] = {
81 CreateMockRead(*resp, 2), 83 CreateMockRead(*resp, 2),
(...skipping 28 matching lines...) Expand all
110 // This triggers read 3. The empty read causes the session to shut down. 112 // This triggers read 3. The empty read causes the session to shut down.
111 data()->CompleteRead(); 113 data()->CompleteRead();
112 114
113 // Because we abandoned the stream, we don't expect to find a session in the 115 // Because we abandoned the stream, we don't expect to find a session in the
114 // pool anymore. 116 // pool anymore.
115 EXPECT_FALSE(http_session_->spdy_session_pool()->HasSession(pair)); 117 EXPECT_FALSE(http_session_->spdy_session_pool()->HasSession(pair));
116 EXPECT_TRUE(data()->at_read_eof()); 118 EXPECT_TRUE(data()->at_read_eof());
117 EXPECT_TRUE(data()->at_write_eof()); 119 EXPECT_TRUE(data()->at_write_eof());
118 } 120 }
119 121
120 TEST_F(SpdyHttpStreamTest, SendChunkedPost) { 122 TEST_F(SpdyHttpStreamSpdy3Test, SendChunkedPost) {
121 EnableCompression(false); 123 EnableCompression(false);
122 SpdySession::SetSSLMode(false); 124 SpdySession::SetSSLMode(false);
123 UploadDataStream::set_merge_chunks(false); 125 UploadDataStream::set_merge_chunks(false);
124 126
125 scoped_ptr<spdy::SpdyFrame> req(ConstructChunkedSpdyPost(NULL, 0)); 127 scoped_ptr<spdy::SpdyFrame> req(ConstructChunkedSpdyPost(NULL, 0));
126 scoped_ptr<spdy::SpdyFrame> chunk1(ConstructSpdyBodyFrame(1, false)); 128 scoped_ptr<spdy::SpdyFrame> chunk1(ConstructSpdyBodyFrame(1, false));
127 scoped_ptr<spdy::SpdyFrame> chunk2(ConstructSpdyBodyFrame(1, true)); 129 scoped_ptr<spdy::SpdyFrame> chunk2(ConstructSpdyBodyFrame(1, true));
128 MockWrite writes[] = { 130 MockWrite writes[] = {
129 CreateMockWrite(*req.get(), 1), 131 CreateMockWrite(*req.get(), 1),
130 CreateMockWrite(*chunk1, 2), // POST upload frames 132 CreateMockWrite(*chunk1, 2), // POST upload frames
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
174 MessageLoop::current()->RunAllPending(); 176 MessageLoop::current()->RunAllPending();
175 177
176 // Because we abandoned the stream, we don't expect to find a session in the 178 // Because we abandoned the stream, we don't expect to find a session in the
177 // pool anymore. 179 // pool anymore.
178 EXPECT_FALSE(http_session_->spdy_session_pool()->HasSession(pair)); 180 EXPECT_FALSE(http_session_->spdy_session_pool()->HasSession(pair));
179 EXPECT_TRUE(data()->at_read_eof()); 181 EXPECT_TRUE(data()->at_read_eof());
180 EXPECT_TRUE(data()->at_write_eof()); 182 EXPECT_TRUE(data()->at_write_eof());
181 } 183 }
182 184
183 // Test case for bug: http://code.google.com/p/chromium/issues/detail?id=50058 185 // Test case for bug: http://code.google.com/p/chromium/issues/detail?id=50058
184 TEST_F(SpdyHttpStreamTest, SpdyURLTest) { 186 TEST_F(SpdyHttpStreamSpdy3Test, SpdyURLTest) {
185 EnableCompression(false); 187 EnableCompression(false);
186 SpdySession::SetSSLMode(false); 188 SpdySession::SetSSLMode(false);
187 189
188 const char * const full_url = "http://www.google.com/foo?query=what#anchor"; 190 const char * const full_url = "http://www.google.com/foo?query=what#anchor";
189 const char * const base_url = "http://www.google.com/foo?query=what"; 191 const char * const base_url = "http://www.google.com/foo?query=what";
190 scoped_ptr<spdy::SpdyFrame> req(ConstructSpdyGet(base_url, false, 1, LOWEST)); 192 scoped_ptr<spdy::SpdyFrame> req(ConstructSpdyGet(base_url, false, 1, LOWEST));
191 MockWrite writes[] = { 193 MockWrite writes[] = {
192 CreateMockWrite(*req.get(), 1), 194 CreateMockWrite(*req.get(), 1),
193 }; 195 };
194 scoped_ptr<spdy::SpdyFrame> resp(ConstructSpdyGetSynReply(NULL, 0, 1)); 196 scoped_ptr<spdy::SpdyFrame> resp(ConstructSpdyGetSynReply(NULL, 0, 1));
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
231 // This triggers read 3. The empty read causes the session to shut down. 233 // This triggers read 3. The empty read causes the session to shut down.
232 data()->CompleteRead(); 234 data()->CompleteRead();
233 235
234 // Because we abandoned the stream, we don't expect to find a session in the 236 // Because we abandoned the stream, we don't expect to find a session in the
235 // pool anymore. 237 // pool anymore.
236 EXPECT_FALSE(http_session_->spdy_session_pool()->HasSession(pair)); 238 EXPECT_FALSE(http_session_->spdy_session_pool()->HasSession(pair));
237 EXPECT_TRUE(data()->at_read_eof()); 239 EXPECT_TRUE(data()->at_read_eof());
238 EXPECT_TRUE(data()->at_write_eof()); 240 EXPECT_TRUE(data()->at_write_eof());
239 } 241 }
240 242
243 namespace {
244
241 void GetECOriginBoundCertAndProof(const std::string& origin, 245 void GetECOriginBoundCertAndProof(const std::string& origin,
242 OriginBoundCertService* obc_service, 246 OriginBoundCertService* obc_service,
243 std::string* cert, 247 std::string* cert,
244 std::string* proof) { 248 std::string* proof) {
245 TestCompletionCallback callback; 249 TestCompletionCallback callback;
246 std::vector<uint8> requested_cert_types; 250 std::vector<uint8> requested_cert_types;
247 requested_cert_types.push_back(CLIENT_CERT_ECDSA_SIGN); 251 requested_cert_types.push_back(CLIENT_CERT_ECDSA_SIGN);
248 SSLClientCertType cert_type; 252 SSLClientCertType cert_type;
249 std::string key; 253 std::string key;
250 OriginBoundCertService::RequestHandle request_handle; 254 OriginBoundCertService::RequestHandle request_handle;
(...skipping 19 matching lines...) Expand all
270 std::vector<uint8> proof_data; 274 std::vector<uint8> proof_data;
271 scoped_ptr<crypto::ECPrivateKey> private_key( 275 scoped_ptr<crypto::ECPrivateKey> private_key(
272 crypto::ECPrivateKey::CreateFromEncryptedPrivateKeyInfo( 276 crypto::ECPrivateKey::CreateFromEncryptedPrivateKeyInfo(
273 OriginBoundCertService::kEPKIPassword, key_data, spki)); 277 OriginBoundCertService::kEPKIPassword, key_data, spki));
274 scoped_ptr<crypto::ECSignatureCreator> creator( 278 scoped_ptr<crypto::ECSignatureCreator> creator(
275 crypto::ECSignatureCreator::Create(private_key.get())); 279 crypto::ECSignatureCreator::Create(private_key.get()));
276 creator->Sign(secret, arraysize(secret), &proof_data); 280 creator->Sign(secret, arraysize(secret), &proof_data);
277 proof->assign(proof_data.begin(), proof_data.end()); 281 proof->assign(proof_data.begin(), proof_data.end());
278 } 282 }
279 283
284 } // namespace
285
280 // TODO(rch): When openssl supports origin bound certifictes, this 286 // TODO(rch): When openssl supports origin bound certifictes, this
281 // guard can be removed 287 // guard can be removed
282 #if !defined(USE_OPENSSL) 288 #if !defined(USE_OPENSSL)
283 // Test that if we request a resource for a new origin on a session that 289 // Test that if we request a resource for a new origin on a session that
284 // used origin bound certificates, that we send a CREDENTIAL frame for 290 // used origin bound certificates, that we send a CREDENTIAL frame for
285 // the new origin before we send the new request. 291 // the new origin before we send the new request.
286 void SpdyHttpStreamTest::TestSendCredentials( 292 void SpdyHttpStreamSpdy3Test::TestSendCredentials(
287 OriginBoundCertService* obc_service, 293 OriginBoundCertService* obc_service,
288 const std::string& cert, 294 const std::string& cert,
289 const std::string& proof, 295 const std::string& proof,
290 SSLClientCertType type) { 296 SSLClientCertType type) {
291 EnableCompression(false); 297 EnableCompression(false);
292 298
293 spdy::SpdyCredential cred; 299 spdy::SpdyCredential cred;
294 cred.slot = 1; 300 cred.slot = 1;
295 cred.proof = proof; 301 cred.proof = proof;
296 cred.certs.push_back(cert); 302 cred.certs.push_back(cert);
(...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after
434 virtual ~MockECSignatureCreatorFactory() {} 440 virtual ~MockECSignatureCreatorFactory() {}
435 441
436 virtual crypto::ECSignatureCreator* Create( 442 virtual crypto::ECSignatureCreator* Create(
437 crypto::ECPrivateKey* key) OVERRIDE { 443 crypto::ECPrivateKey* key) OVERRIDE {
438 return new MockECSignatureCreator(key); 444 return new MockECSignatureCreator(key);
439 } 445 }
440 private: 446 private:
441 DISALLOW_COPY_AND_ASSIGN(MockECSignatureCreatorFactory); 447 DISALLOW_COPY_AND_ASSIGN(MockECSignatureCreatorFactory);
442 }; 448 };
443 449
444 TEST_F(SpdyHttpStreamTest, SendCredentialsEC) { 450 TEST_F(SpdyHttpStreamSpdy3Test, SendCredentialsEC) {
445 scoped_ptr<crypto::ECSignatureCreatorFactory> ec_signature_creator_factory( 451 scoped_ptr<crypto::ECSignatureCreatorFactory> ec_signature_creator_factory(
446 new MockECSignatureCreatorFactory()); 452 new MockECSignatureCreatorFactory());
447 crypto::ECSignatureCreator::SetFactoryForTesting( 453 crypto::ECSignatureCreator::SetFactoryForTesting(
448 ec_signature_creator_factory.get()); 454 ec_signature_creator_factory.get());
449 455
450 scoped_ptr<OriginBoundCertService> obc_service( 456 scoped_ptr<OriginBoundCertService> obc_service(
451 new OriginBoundCertService(new DefaultOriginBoundCertStore(NULL))); 457 new OriginBoundCertService(new DefaultOriginBoundCertStore(NULL)));
452 std::string cert; 458 std::string cert;
453 std::string proof; 459 std::string proof;
454 GetECOriginBoundCertAndProof("http://www.gmail.com/", obc_service.get(), 460 GetECOriginBoundCertAndProof("http://www.gmail.com/", obc_service.get(),
455 &cert, &proof); 461 &cert, &proof);
456 462
457 TestSendCredentials(obc_service.get(), cert, proof, CLIENT_CERT_ECDSA_SIGN); 463 TestSendCredentials(obc_service.get(), cert, proof, CLIENT_CERT_ECDSA_SIGN);
458 } 464 }
459 465
460 #endif // !defined(USE_OPENSSL) 466 #endif // !defined(USE_OPENSSL)
461 467
462 // TODO(willchan): Write a longer test for SpdyStream that exercises all 468 // TODO(willchan): Write a longer test for SpdyStream that exercises all
463 // methods. 469 // methods.
464 470
465 } // namespace net 471 } // namespace net
OLDNEW
« no previous file with comments | « net/spdy/spdy_http_stream_spdy2_unittest.cc ('k') | net/spdy/spdy_http_stream_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698