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

Side by Side Diff: net/tools/quic/quic_simple_server_stream_test.cc

Issue 1989503002: Add an additional ReliableQuicStream* argument to QuicSession::WritevData in an attempt to defend a… (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@122078733
Patch Set: Created 4 years, 7 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
« no previous file with comments | « net/tools/quic/quic_client_session_test.cc ('k') | no next file » | 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) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 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/tools/quic/quic_simple_server_stream.h" 5 #include "net/tools/quic/quic_simple_server_stream.h"
6 6
7 #include "base/strings/string_number_conversions.h" 7 #include "base/strings/string_number_conversions.h"
8 #include "base/strings/string_piece.h" 8 #include "base/strings/string_piece.h"
9 #include "net/quic/quic_connection.h" 9 #include "net/quic/quic_connection.h"
10 #include "net/quic/quic_flags.h" 10 #include "net/quic/quic_flags.h"
(...skipping 24 matching lines...) Expand all
35 using std::string; 35 using std::string;
36 using testing::_; 36 using testing::_;
37 using testing::AnyNumber; 37 using testing::AnyNumber;
38 using testing::Invoke; 38 using testing::Invoke;
39 using testing::InvokeArgument; 39 using testing::InvokeArgument;
40 using testing::InSequence; 40 using testing::InSequence;
41 using testing::Return; 41 using testing::Return;
42 using testing::StrictMock; 42 using testing::StrictMock;
43 using testing::WithArgs; 43 using testing::WithArgs;
44 44
45 DECLARE_bool(quic_always_log_bugs_for_tests);
46
47 namespace net { 45 namespace net {
48 namespace test { 46 namespace test {
49 47
50 class QuicSimpleServerStreamPeer : public QuicSimpleServerStream { 48 class QuicSimpleServerStreamPeer : public QuicSimpleServerStream {
51 public: 49 public:
52 QuicSimpleServerStreamPeer(QuicStreamId stream_id, QuicSpdySession* session) 50 QuicSimpleServerStreamPeer(QuicStreamId stream_id, QuicSpdySession* session)
53 : QuicSimpleServerStream(stream_id, session) {} 51 : QuicSimpleServerStream(stream_id, session) {}
54 52
55 ~QuicSimpleServerStreamPeer() override{}; 53 ~QuicSimpleServerStreamPeer() override{};
56 54
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
89 MockQuicServerSessionVisitor* owner, 87 MockQuicServerSessionVisitor* owner,
90 QuicCryptoServerConfig* crypto_config, 88 QuicCryptoServerConfig* crypto_config,
91 QuicCompressedCertsCache* compressed_certs_cache) 89 QuicCompressedCertsCache* compressed_certs_cache)
92 : QuicSimpleServerSession(DefaultQuicConfig(), 90 : QuicSimpleServerSession(DefaultQuicConfig(),
93 connection, 91 connection,
94 owner, 92 owner,
95 crypto_config, 93 crypto_config,
96 compressed_certs_cache) { 94 compressed_certs_cache) {
97 set_max_open_incoming_streams(kMaxStreamsForTest); 95 set_max_open_incoming_streams(kMaxStreamsForTest);
98 set_max_open_outgoing_streams(kMaxStreamsForTest); 96 set_max_open_outgoing_streams(kMaxStreamsForTest);
99 ON_CALL(*this, WritevData(_, _, _, _, _)) 97 ON_CALL(*this, WritevData(_, _, _, _, _, _))
100 .WillByDefault(testing::Return(QuicConsumedData(0, false))); 98 .WillByDefault(testing::Return(QuicConsumedData(0, false)));
101 } 99 }
102 100
103 ~MockQuicSimpleServerSession() override {} 101 ~MockQuicSimpleServerSession() override {}
104 102
105 MOCK_METHOD3(OnConnectionClosed, 103 MOCK_METHOD3(OnConnectionClosed,
106 void(QuicErrorCode error, 104 void(QuicErrorCode error,
107 const string& error_details, 105 const string& error_details,
108 ConnectionCloseSource source)); 106 ConnectionCloseSource source));
109 MOCK_METHOD1(CreateIncomingDynamicStream, QuicSpdyStream*(QuicStreamId id)); 107 MOCK_METHOD1(CreateIncomingDynamicStream, QuicSpdyStream*(QuicStreamId id));
110 MOCK_METHOD5(WritevData, 108 MOCK_METHOD6(WritevData,
111 QuicConsumedData(QuicStreamId id, 109 QuicConsumedData(ReliableQuicStream* stream,
110 QuicStreamId id,
112 QuicIOVector data, 111 QuicIOVector data,
113 QuicStreamOffset offset, 112 QuicStreamOffset offset,
114 bool fin, 113 bool fin,
115 QuicAckListenerInterface*)); 114 QuicAckListenerInterface*));
116 MOCK_METHOD2(OnStreamHeaders, 115 MOCK_METHOD2(OnStreamHeaders,
117 void(QuicStreamId stream_id, StringPiece headers_data)); 116 void(QuicStreamId stream_id, StringPiece headers_data));
118 MOCK_METHOD2(OnStreamHeadersPriority, 117 MOCK_METHOD2(OnStreamHeadersPriority,
119 void(QuicStreamId stream_id, SpdyPriority priority)); 118 void(QuicStreamId stream_id, SpdyPriority priority));
120 MOCK_METHOD3(OnStreamHeadersComplete, 119 MOCK_METHOD3(OnStreamHeadersComplete,
121 void(QuicStreamId stream_id, bool fin, size_t frame_len)); 120 void(QuicStreamId stream_id, bool fin, size_t frame_len));
122 MOCK_METHOD5(WriteHeaders, 121 MOCK_METHOD5(WriteHeaders,
123 size_t(QuicStreamId id, 122 size_t(QuicStreamId id,
124 const SpdyHeaderBlock& headers, 123 const SpdyHeaderBlock& headers,
125 bool fin, 124 bool fin,
126 SpdyPriority priority, 125 SpdyPriority priority,
127 QuicAckListenerInterface* ack_notifier_delegate)); 126 QuicAckListenerInterface* ack_notifier_delegate));
128 MOCK_METHOD3(SendRstStream, 127 MOCK_METHOD3(SendRstStream,
129 void(QuicStreamId stream_id, 128 void(QuicStreamId stream_id,
130 QuicRstStreamErrorCode error, 129 QuicRstStreamErrorCode error,
131 QuicStreamOffset bytes_written)); 130 QuicStreamOffset bytes_written));
132 MOCK_METHOD1(OnHeadersHeadOfLineBlocking, void(QuicTime::Delta delta)); 131 MOCK_METHOD1(OnHeadersHeadOfLineBlocking, void(QuicTime::Delta delta));
133 MOCK_METHOD4(PromisePushResources, 132 MOCK_METHOD4(PromisePushResources,
134 void(const string&, 133 void(const string&,
135 const list<QuicInMemoryCache::ServerPushInfo>&, 134 const std::list<QuicInMemoryCache::ServerPushInfo>&,
136 QuicStreamId, 135 QuicStreamId,
137 const SpdyHeaderBlock&)); 136 const SpdyHeaderBlock&));
138 137
139 using QuicSession::ActivateStream; 138 using QuicSession::ActivateStream;
140 139
141 private: 140 private:
142 DISALLOW_COPY_AND_ASSIGN(MockQuicSimpleServerSession); 141 DISALLOW_COPY_AND_ASSIGN(MockQuicSimpleServerSession);
143 }; 142 };
144 143
145 namespace { 144 namespace {
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after
214 QuicSimpleServerStreamPeer* stream_; // Owned by session_. 213 QuicSimpleServerStreamPeer* stream_; // Owned by session_.
215 string headers_string_; 214 string headers_string_;
216 string body_; 215 string body_;
217 }; 216 };
218 217
219 INSTANTIATE_TEST_CASE_P(Tests, 218 INSTANTIATE_TEST_CASE_P(Tests,
220 QuicSimpleServerStreamTest, 219 QuicSimpleServerStreamTest,
221 ::testing::ValuesIn(QuicSupportedVersions())); 220 ::testing::ValuesIn(QuicSupportedVersions()));
222 221
223 TEST_P(QuicSimpleServerStreamTest, TestFraming) { 222 TEST_P(QuicSimpleServerStreamTest, TestFraming) {
224 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 223 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
225 .Times(AnyNumber()) 224 .Times(AnyNumber())
226 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData)); 225 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData));
227 stream_->OnStreamHeaders(headers_string_); 226 stream_->OnStreamHeaders(headers_string_);
228 stream_->OnStreamHeadersComplete(false, headers_string_.size()); 227 stream_->OnStreamHeadersComplete(false, headers_string_.size());
229 stream_->OnStreamFrame( 228 stream_->OnStreamFrame(
230 QuicStreamFrame(stream_->id(), /*fin=*/false, /*offset=*/0, body_)); 229 QuicStreamFrame(stream_->id(), /*fin=*/false, /*offset=*/0, body_));
231 EXPECT_EQ("11", StreamHeadersValue("content-length")); 230 EXPECT_EQ("11", StreamHeadersValue("content-length"));
232 EXPECT_EQ("/", StreamHeadersValue(":path")); 231 EXPECT_EQ("/", StreamHeadersValue(":path"));
233 EXPECT_EQ("POST", StreamHeadersValue(":method")); 232 EXPECT_EQ("POST", StreamHeadersValue(":method"));
234 EXPECT_EQ(body_, StreamBody()); 233 EXPECT_EQ(body_, StreamBody());
235 } 234 }
236 235
237 TEST_P(QuicSimpleServerStreamTest, TestFramingOnePacket) { 236 TEST_P(QuicSimpleServerStreamTest, TestFramingOnePacket) {
238 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 237 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
239 .Times(AnyNumber()) 238 .Times(AnyNumber())
240 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData)); 239 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData));
241 240
242 stream_->OnStreamHeaders(headers_string_); 241 stream_->OnStreamHeaders(headers_string_);
243 stream_->OnStreamHeadersComplete(false, headers_string_.size()); 242 stream_->OnStreamHeadersComplete(false, headers_string_.size());
244 stream_->OnStreamFrame( 243 stream_->OnStreamFrame(
245 QuicStreamFrame(stream_->id(), /*fin=*/false, /*offset=*/0, body_)); 244 QuicStreamFrame(stream_->id(), /*fin=*/false, /*offset=*/0, body_));
246 EXPECT_EQ("11", StreamHeadersValue("content-length")); 245 EXPECT_EQ("11", StreamHeadersValue("content-length"));
247 EXPECT_EQ("/", StreamHeadersValue(":path")); 246 EXPECT_EQ("/", StreamHeadersValue(":path"));
248 EXPECT_EQ("POST", StreamHeadersValue(":method")); 247 EXPECT_EQ("POST", StreamHeadersValue(":method"));
249 EXPECT_EQ(body_, StreamBody()); 248 EXPECT_EQ(body_, StreamBody());
250 } 249 }
251 250
252 TEST_P(QuicSimpleServerStreamTest, SendQuicRstStreamNoErrorInStopReading) { 251 TEST_P(QuicSimpleServerStreamTest, SendQuicRstStreamNoErrorInStopReading) {
253 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 252 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
254 .Times(AnyNumber()) 253 .Times(AnyNumber())
255 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData)); 254 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData));
256 255
257 EXPECT_FALSE(stream_->fin_received()); 256 EXPECT_FALSE(stream_->fin_received());
258 EXPECT_FALSE(stream_->rst_received()); 257 EXPECT_FALSE(stream_->rst_received());
259 258
260 stream_->set_fin_sent(true); 259 stream_->set_fin_sent(true);
261 stream_->CloseWriteSide(); 260 stream_->CloseWriteSide();
262 261
263 if (GetParam() > QUIC_VERSION_28) { 262 if (GetParam() > QUIC_VERSION_28) {
264 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(1); 263 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(1);
265 } else { 264 } else {
266 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0); 265 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0);
267 } 266 }
268 stream_->StopReading(); 267 stream_->StopReading();
269 } 268 }
270 269
271 TEST_P(QuicSimpleServerStreamTest, TestFramingExtraData) { 270 TEST_P(QuicSimpleServerStreamTest, TestFramingExtraData) {
272 string large_body = "hello world!!!!!!"; 271 string large_body = "hello world!!!!!!";
273 272
274 // We'll automatically write out an error (headers + body) 273 // We'll automatically write out an error (headers + body)
275 EXPECT_CALL(session_, WriteHeaders(_, _, _, _, _)); 274 EXPECT_CALL(session_, WriteHeaders(_, _, _, _, _));
276 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 275 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
277 .WillOnce(Invoke(MockQuicSession::ConsumeAllData)); 276 .WillOnce(Invoke(MockQuicSession::ConsumeAllData));
278 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0); 277 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0);
279 278
280 stream_->OnStreamHeaders(headers_string_); 279 stream_->OnStreamHeaders(headers_string_);
281 stream_->OnStreamHeadersComplete(false, headers_string_.size()); 280 stream_->OnStreamHeadersComplete(false, headers_string_.size());
282 stream_->OnStreamFrame( 281 stream_->OnStreamFrame(
283 QuicStreamFrame(stream_->id(), /*fin=*/false, /*offset=*/0, body_)); 282 QuicStreamFrame(stream_->id(), /*fin=*/false, /*offset=*/0, body_));
284 // Content length is still 11. This will register as an error and we won't 283 // Content length is still 11. This will register as an error and we won't
285 // accept the bytes. 284 // accept the bytes.
286 stream_->OnStreamFrame( 285 stream_->OnStreamFrame(
(...skipping 16 matching lines...) Expand all
303 response_headers_[":status"] = "200 OK"; 302 response_headers_[":status"] = "200 OK";
304 response_headers_["content-length"] = "5"; 303 response_headers_["content-length"] = "5";
305 string body = "Yummm"; 304 string body = "Yummm";
306 QuicInMemoryCache::GetInstance()->AddResponse("www.google.com", "/bar", 305 QuicInMemoryCache::GetInstance()->AddResponse("www.google.com", "/bar",
307 response_headers_, body); 306 response_headers_, body);
308 307
309 stream_->set_fin_received(true); 308 stream_->set_fin_received(true);
310 309
311 InSequence s; 310 InSequence s;
312 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, false, _, nullptr)); 311 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, false, _, nullptr));
313 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 312 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
314 .Times(1) 313 .Times(1)
315 .WillOnce(Return(QuicConsumedData( 314 .WillOnce(Return(QuicConsumedData(
316 strlen(QuicSimpleServerStream::kErrorResponseBody), true))); 315 strlen(QuicSimpleServerStream::kErrorResponseBody), true)));
317 316
318 QuicSimpleServerStreamPeer::SendResponse(stream_); 317 QuicSimpleServerStreamPeer::SendResponse(stream_);
319 EXPECT_FALSE(ReliableQuicStreamPeer::read_side_closed(stream_)); 318 EXPECT_FALSE(ReliableQuicStreamPeer::read_side_closed(stream_));
320 EXPECT_TRUE(stream_->reading_stopped()); 319 EXPECT_TRUE(stream_->reading_stopped());
321 EXPECT_TRUE(stream_->write_side_closed()); 320 EXPECT_TRUE(stream_->write_side_closed());
322 } 321 }
323 322
(...skipping 10 matching lines...) Expand all
334 response_headers_[":status"] = "+200"; 333 response_headers_[":status"] = "+200";
335 response_headers_["content-length"] = "5"; 334 response_headers_["content-length"] = "5";
336 string body = "Yummm"; 335 string body = "Yummm";
337 QuicInMemoryCache::GetInstance()->AddResponse("www.google.com", "/bar", 336 QuicInMemoryCache::GetInstance()->AddResponse("www.google.com", "/bar",
338 response_headers_, body); 337 response_headers_, body);
339 338
340 stream_->set_fin_received(true); 339 stream_->set_fin_received(true);
341 340
342 InSequence s; 341 InSequence s;
343 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, false, _, nullptr)); 342 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, false, _, nullptr));
344 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 343 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
345 .Times(1) 344 .Times(1)
346 .WillOnce(Return(QuicConsumedData( 345 .WillOnce(Return(QuicConsumedData(
347 strlen(QuicSimpleServerStream::kErrorResponseBody), true))); 346 strlen(QuicSimpleServerStream::kErrorResponseBody), true)));
348 347
349 QuicSimpleServerStreamPeer::SendResponse(stream_); 348 QuicSimpleServerStreamPeer::SendResponse(stream_);
350 EXPECT_FALSE(ReliableQuicStreamPeer::read_side_closed(stream_)); 349 EXPECT_FALSE(ReliableQuicStreamPeer::read_side_closed(stream_));
351 EXPECT_TRUE(stream_->reading_stopped()); 350 EXPECT_TRUE(stream_->reading_stopped());
352 EXPECT_TRUE(stream_->write_side_closed()); 351 EXPECT_TRUE(stream_->write_side_closed());
353 } 352 }
354 353
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
391 response_headers_[":version"] = "HTTP/1.1"; 390 response_headers_[":version"] = "HTTP/1.1";
392 response_headers_[":status"] = "200"; 391 response_headers_[":status"] = "200";
393 response_headers_["content-length"] = "5"; 392 response_headers_["content-length"] = "5";
394 string body = "Yummm"; 393 string body = "Yummm";
395 QuicInMemoryCache::GetInstance()->AddResponse("www.google.com", "/bar", 394 QuicInMemoryCache::GetInstance()->AddResponse("www.google.com", "/bar",
396 response_headers_, body); 395 response_headers_, body);
397 stream_->set_fin_received(true); 396 stream_->set_fin_received(true);
398 397
399 InSequence s; 398 InSequence s;
400 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, false, _, nullptr)); 399 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, false, _, nullptr));
401 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 400 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
402 .Times(1) 401 .Times(1)
403 .WillOnce(Return(QuicConsumedData(body.length(), true))); 402 .WillOnce(Return(QuicConsumedData(body.length(), true)));
404 403
405 QuicSimpleServerStreamPeer::SendResponse(stream_); 404 QuicSimpleServerStreamPeer::SendResponse(stream_);
406 EXPECT_FALSE(ReliableQuicStreamPeer::read_side_closed(stream_)); 405 EXPECT_FALSE(ReliableQuicStreamPeer::read_side_closed(stream_));
407 EXPECT_TRUE(stream_->reading_stopped()); 406 EXPECT_TRUE(stream_->reading_stopped());
408 EXPECT_TRUE(stream_->write_side_closed()); 407 EXPECT_TRUE(stream_->write_side_closed());
409 } 408 }
410 409
411 TEST_P(QuicSimpleServerStreamTest, SendReponseWithPushResources) { 410 TEST_P(QuicSimpleServerStreamTest, SendReponseWithPushResources) {
412 // Tests that if a reponse has push resources to be send, SendResponse() will 411 // Tests that if a reponse has push resources to be send, SendResponse() will
413 // call PromisePushResources() to handle these resources. 412 // call PromisePushResources() to handle these resources.
414 413
415 // Add a request and response with valid headers into cache. 414 // Add a request and response with valid headers into cache.
416 string host = "www.google.com"; 415 string host = "www.google.com";
417 string request_path = "/foo"; 416 string request_path = "/foo";
418 string body = "Yummm"; 417 string body = "Yummm";
419 SpdyHeaderBlock response_headers; 418 SpdyHeaderBlock response_headers;
420 string url = host + "/bar"; 419 string url = host + "/bar";
421 QuicInMemoryCache::ServerPushInfo push_info(GURL(url), response_headers, 420 QuicInMemoryCache::ServerPushInfo push_info(GURL(url), response_headers,
422 kDefaultPriority, "Push body"); 421 kDefaultPriority, "Push body");
423 list<QuicInMemoryCache::ServerPushInfo> push_resources; 422 std::list<QuicInMemoryCache::ServerPushInfo> push_resources;
424 push_resources.push_back(push_info); 423 push_resources.push_back(push_info);
425 QuicInMemoryCache::GetInstance()->AddSimpleResponseWithServerPushResources( 424 QuicInMemoryCache::GetInstance()->AddSimpleResponseWithServerPushResources(
426 host, request_path, 200, body, push_resources); 425 host, request_path, 200, body, push_resources);
427 426
428 SpdyHeaderBlock* request_headers = stream_->mutable_headers(); 427 SpdyHeaderBlock* request_headers = stream_->mutable_headers();
429 (*request_headers)[":path"] = request_path; 428 (*request_headers)[":path"] = request_path;
430 (*request_headers)[":authority"] = host; 429 (*request_headers)[":authority"] = host;
431 (*request_headers)[":version"] = "HTTP/1.1"; 430 (*request_headers)[":version"] = "HTTP/1.1";
432 (*request_headers)[":method"] = "GET"; 431 (*request_headers)[":method"] = "GET";
433 432
434 stream_->set_fin_received(true); 433 stream_->set_fin_received(true);
435 InSequence s; 434 InSequence s;
436 EXPECT_CALL(session_, PromisePushResources(host + request_path, _, 435 EXPECT_CALL(session_, PromisePushResources(host + request_path, _,
437 ::net::test::kClientDataStreamId1, 436 ::net::test::kClientDataStreamId1,
438 *request_headers)); 437 *request_headers));
439 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, false, _, nullptr)); 438 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, false, _, nullptr));
440 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 439 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
441 .Times(1) 440 .Times(1)
442 .WillOnce(Return(QuicConsumedData(body.length(), true))); 441 .WillOnce(Return(QuicConsumedData(body.length(), true)));
443 QuicSimpleServerStreamPeer::SendResponse(stream_); 442 QuicSimpleServerStreamPeer::SendResponse(stream_);
444 } 443 }
445 444
446 TEST_P(QuicSimpleServerStreamTest, PushResponseOnClientInitiatedStream) { 445 TEST_P(QuicSimpleServerStreamTest, PushResponseOnClientInitiatedStream) {
447 // Calling PushResponse() on a client initialted stream is never supposed to 446 // Calling PushResponse() on a client initialted stream is never supposed to
448 // happen. 447 // happen.
449 SpdyHeaderBlock headers; 448 SpdyHeaderBlock headers;
450 EXPECT_DFATAL(stream_->PushResponse(headers), 449 EXPECT_DFATAL(stream_->PushResponse(headers),
(...skipping 25 matching lines...) Expand all
476 response_headers_["content-length"] = "5"; 475 response_headers_["content-length"] = "5";
477 const string kBody = "Hello"; 476 const string kBody = "Hello";
478 QuicInMemoryCache::GetInstance()->AddResponse(kHost, kPath, response_headers_, 477 QuicInMemoryCache::GetInstance()->AddResponse(kHost, kPath, response_headers_,
479 kBody); 478 kBody);
480 479
481 // Call PushResponse() should trigger stream to fetch response from cache 480 // Call PushResponse() should trigger stream to fetch response from cache
482 // and send it back. 481 // and send it back.
483 EXPECT_CALL(session_, 482 EXPECT_CALL(session_,
484 WriteHeaders(kServerInitiatedStreamId, _, false, 483 WriteHeaders(kServerInitiatedStreamId, _, false,
485 server_initiated_stream->priority(), nullptr)); 484 server_initiated_stream->priority(), nullptr));
486 EXPECT_CALL(session_, WritevData(kServerInitiatedStreamId, _, _, _, _)) 485 EXPECT_CALL(session_, WritevData(_, kServerInitiatedStreamId, _, _, _, _))
487 .Times(1) 486 .Times(1)
488 .WillOnce(Return(QuicConsumedData(kBody.size(), true))); 487 .WillOnce(Return(QuicConsumedData(kBody.size(), true)));
489 server_initiated_stream->PushResponse(headers); 488 server_initiated_stream->PushResponse(headers);
490 EXPECT_EQ(kPath, QuicSimpleServerStreamPeer::headers( 489 EXPECT_EQ(kPath, QuicSimpleServerStreamPeer::headers(
491 server_initiated_stream)[":path"] 490 server_initiated_stream)[":path"]
492 .as_string()); 491 .as_string());
493 EXPECT_EQ("GET", QuicSimpleServerStreamPeer::headers( 492 EXPECT_EQ("GET", QuicSimpleServerStreamPeer::headers(
494 server_initiated_stream)[":method"] 493 server_initiated_stream)[":method"]
495 .as_string()); 494 .as_string());
496 } 495 }
497 496
498 TEST_P(QuicSimpleServerStreamTest, TestSendErrorResponse) { 497 TEST_P(QuicSimpleServerStreamTest, TestSendErrorResponse) {
499 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0); 498 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0);
500 499
501 response_headers_[":version"] = "HTTP/1.1"; 500 response_headers_[":version"] = "HTTP/1.1";
502 response_headers_[":status"] = "500 Server Error"; 501 response_headers_[":status"] = "500 Server Error";
503 response_headers_["content-length"] = "3"; 502 response_headers_["content-length"] = "3";
504 stream_->set_fin_received(true); 503 stream_->set_fin_received(true);
505 504
506 InSequence s; 505 InSequence s;
507 EXPECT_CALL(session_, WriteHeaders(_, _, _, _, _)); 506 EXPECT_CALL(session_, WriteHeaders(_, _, _, _, _));
508 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 507 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
509 .Times(1) 508 .Times(1)
510 .WillOnce(Return(QuicConsumedData(3, true))); 509 .WillOnce(Return(QuicConsumedData(3, true)));
511 510
512 QuicSimpleServerStreamPeer::SendErrorResponse(stream_); 511 QuicSimpleServerStreamPeer::SendErrorResponse(stream_);
513 EXPECT_FALSE(ReliableQuicStreamPeer::read_side_closed(stream_)); 512 EXPECT_FALSE(ReliableQuicStreamPeer::read_side_closed(stream_));
514 EXPECT_TRUE(stream_->reading_stopped()); 513 EXPECT_TRUE(stream_->reading_stopped());
515 EXPECT_TRUE(stream_->write_side_closed()); 514 EXPECT_TRUE(stream_->write_side_closed());
516 } 515 }
517 516
518 TEST_P(QuicSimpleServerStreamTest, InvalidMultipleContentLength) { 517 TEST_P(QuicSimpleServerStreamTest, InvalidMultipleContentLength) {
519 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0); 518 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0);
520 519
521 SpdyHeaderBlock request_headers; 520 SpdyHeaderBlock request_headers;
522 // \000 is a way to write the null byte when followed by a literal digit. 521 // \000 is a way to write the null byte when followed by a literal digit.
523 request_headers["content-length"] = StringPiece("11\00012", 5); 522 request_headers["content-length"] = StringPiece("11\00012", 5);
524 523
525 headers_string_ = SpdyUtils::SerializeUncompressedHeaders(request_headers); 524 headers_string_ = SpdyUtils::SerializeUncompressedHeaders(request_headers);
526 525
527 EXPECT_CALL(session_, WriteHeaders(_, _, _, _, _)); 526 EXPECT_CALL(session_, WriteHeaders(_, _, _, _, _));
528 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 527 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
529 .Times(AnyNumber()) 528 .Times(AnyNumber())
530 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData)); 529 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData));
531 stream_->OnStreamHeaders(headers_string_); 530 stream_->OnStreamHeaders(headers_string_);
532 stream_->OnStreamHeadersComplete(true, headers_string_.size()); 531 stream_->OnStreamHeadersComplete(true, headers_string_.size());
533 532
534 EXPECT_TRUE(ReliableQuicStreamPeer::read_side_closed(stream_)); 533 EXPECT_TRUE(ReliableQuicStreamPeer::read_side_closed(stream_));
535 EXPECT_TRUE(stream_->reading_stopped()); 534 EXPECT_TRUE(stream_->reading_stopped());
536 EXPECT_TRUE(stream_->write_side_closed()); 535 EXPECT_TRUE(stream_->write_side_closed());
537 } 536 }
538 537
539 TEST_P(QuicSimpleServerStreamTest, InvalidLeadingNullContentLength) { 538 TEST_P(QuicSimpleServerStreamTest, InvalidLeadingNullContentLength) {
540 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0); 539 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0);
541 540
542 SpdyHeaderBlock request_headers; 541 SpdyHeaderBlock request_headers;
543 // \000 is a way to write the null byte when followed by a literal digit. 542 // \000 is a way to write the null byte when followed by a literal digit.
544 request_headers["content-length"] = StringPiece("\00012", 3); 543 request_headers["content-length"] = StringPiece("\00012", 3);
545 544
546 headers_string_ = SpdyUtils::SerializeUncompressedHeaders(request_headers); 545 headers_string_ = SpdyUtils::SerializeUncompressedHeaders(request_headers);
547 546
548 EXPECT_CALL(session_, WriteHeaders(_, _, _, _, _)); 547 EXPECT_CALL(session_, WriteHeaders(_, _, _, _, _));
549 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 548 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
550 .Times(AnyNumber()) 549 .Times(AnyNumber())
551 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData)); 550 .WillRepeatedly(Invoke(MockQuicSession::ConsumeAllData));
552 stream_->OnStreamHeaders(headers_string_); 551 stream_->OnStreamHeaders(headers_string_);
553 stream_->OnStreamHeadersComplete(true, headers_string_.size()); 552 stream_->OnStreamHeadersComplete(true, headers_string_.size());
554 553
555 EXPECT_TRUE(ReliableQuicStreamPeer::read_side_closed(stream_)); 554 EXPECT_TRUE(ReliableQuicStreamPeer::read_side_closed(stream_));
556 EXPECT_TRUE(stream_->reading_stopped()); 555 EXPECT_TRUE(stream_->reading_stopped());
557 EXPECT_TRUE(stream_->write_side_closed()); 556 EXPECT_TRUE(stream_->write_side_closed());
558 } 557 }
559 558
(...skipping 13 matching lines...) Expand all
573 EXPECT_FALSE(stream_->write_side_closed()); 572 EXPECT_FALSE(stream_->write_side_closed());
574 } 573 }
575 574
576 TEST_P(QuicSimpleServerStreamTest, SendQuicRstStreamNoErrorWithEarlyResponse) { 575 TEST_P(QuicSimpleServerStreamTest, SendQuicRstStreamNoErrorWithEarlyResponse) {
577 response_headers_[":version"] = "HTTP/1.1"; 576 response_headers_[":version"] = "HTTP/1.1";
578 response_headers_[":status"] = "500 Server Error"; 577 response_headers_[":status"] = "500 Server Error";
579 response_headers_["content-length"] = "3"; 578 response_headers_["content-length"] = "3";
580 579
581 InSequence s; 580 InSequence s;
582 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, _, _, _)); 581 EXPECT_CALL(session_, WriteHeaders(stream_->id(), _, _, _, _));
583 EXPECT_CALL(session_, WritevData(_, _, _, _, _)) 582 EXPECT_CALL(session_, WritevData(_, _, _, _, _, _))
584 .Times(1) 583 .Times(1)
585 .WillOnce(Return(QuicConsumedData(3, true))); 584 .WillOnce(Return(QuicConsumedData(3, true)));
586 if (GetParam() > QUIC_VERSION_28) { 585 if (GetParam() > QUIC_VERSION_28) {
587 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(1); 586 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(1);
588 } else { 587 } else {
589 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0); 588 EXPECT_CALL(session_, SendRstStream(_, QUIC_STREAM_NO_ERROR, _)).Times(0);
590 } 589 }
591 EXPECT_FALSE(stream_->fin_received()); 590 EXPECT_FALSE(stream_->fin_received());
592 QuicSimpleServerStreamPeer::SendErrorResponse(stream_); 591 QuicSimpleServerStreamPeer::SendErrorResponse(stream_);
593 EXPECT_TRUE(stream_->reading_stopped()); 592 EXPECT_TRUE(stream_->reading_stopped());
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after
638 }; 637 };
639 StringPiece data(arr, arraysize(arr)); 638 StringPiece data(arr, arraysize(arr));
640 QuicStreamFrame frame(stream_->id(), true, 0, data); 639 QuicStreamFrame frame(stream_->id(), true, 0, data);
641 // Verify that we don't crash when we get a invalid headers in stream frame. 640 // Verify that we don't crash when we get a invalid headers in stream frame.
642 stream_->OnStreamFrame(frame); 641 stream_->OnStreamFrame(frame);
643 } 642 }
644 643
645 } // namespace 644 } // namespace
646 } // namespace test 645 } // namespace test
647 } // namespace net 646 } // namespace net
OLDNEW
« no previous file with comments | « net/tools/quic/quic_client_session_test.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698