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

Unified Diff: net/quic/quic_network_transaction_unittest.cc

Issue 2107353003: QUIC - expand server push test coverage and fix recent regression. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: QUIC - expand server push test coverage and fix recent regression. Created 4 years, 6 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/quic/quic_chromium_client_stream.cc ('k') | net/quic/test_tools/quic_test_packet_maker.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/quic/quic_network_transaction_unittest.cc
diff --git a/net/quic/quic_network_transaction_unittest.cc b/net/quic/quic_network_transaction_unittest.cc
index 7460a51eb7253ab7a5a640f90cd714ca15344ce4..d440e96b4283814dc7f705689a22759a96ea9e2d 100644
--- a/net/quic/quic_network_transaction_unittest.cc
+++ b/net/quic/quic_network_transaction_unittest.cc
@@ -333,6 +333,16 @@ class QuicNetworkTransactionTest
least_unacked, true);
}
+ std::unique_ptr<QuicEncryptedPacket> ConstructClientAckPacket(
+ QuicPacketNumber packet_number,
+ QuicPacketNumber largest_received,
+ QuicPacketNumber ack_least_unacked,
+ QuicPacketNumber stop_least_unacked) {
+ return client_maker_.MakeAckPacket(packet_number, largest_received,
+ ack_least_unacked, stop_least_unacked,
+ true);
+ }
+
std::unique_ptr<QuicEncryptedPacket>
ConstructClientAckAndConnectionClosePacket(
QuicPacketNumber packet_number,
@@ -453,6 +463,19 @@ class QuicNetworkTransactionTest
std::move(headers), nullptr, maker);
}
+ std::unique_ptr<QuicEncryptedPacket> ConstructServerPushPromisePacket(
+ QuicPacketNumber packet_number,
+ QuicStreamId stream_id,
+ QuicStreamId promised_stream_id,
+ bool should_include_version,
+ SpdyHeaderBlock headers,
+ QuicStreamOffset* offset,
+ QuicTestPacketMaker* maker) {
+ return maker->MakePushPromisePacket(
+ packet_number, stream_id, promised_stream_id, should_include_version,
+ false, std::move(headers), nullptr, offset);
+ }
+
std::unique_ptr<QuicEncryptedPacket> ConstructServerResponseHeadersPacket(
QuicPacketNumber packet_number,
QuicStreamId stream_id,
@@ -2246,6 +2269,62 @@ TEST_P(QuicNetworkTransactionTest, QuicUpload) {
EXPECT_NE(OK, callback.WaitForResult());
}
+// Adds coverage to catch regression such as https://crbug.com/622043
+TEST_P(QuicNetworkTransactionTest, QuicServerPush) {
+ params_.origins_to_force_quic_on.insert(
+ HostPortPair::FromString("mail.example.org:443"));
+
+ MockQuicData mock_quic_data;
+ mock_quic_data.AddWrite(ConstructClientRequestHeadersPacket(
+ 1, kClientDataStreamId1, true, true,
+ GetRequestHeaders("GET", "https", "/")));
+ QuicStreamOffset server_header_offset = 0;
+ mock_quic_data.AddRead(ConstructServerPushPromisePacket(
+ 1, kClientDataStreamId1, kServerDataStreamId1, false,
+ GetRequestHeaders("GET", "https", "/pushed.jpg"), &server_header_offset,
+ &server_maker_));
+ mock_quic_data.AddRead(ConstructServerResponseHeadersPacket(
+ 2, kClientDataStreamId1, false, false, GetResponseHeaders("200 OK"),
+ &server_header_offset));
+ mock_quic_data.AddWrite(ConstructClientAckPacket(2, 2, 1, 1));
+ mock_quic_data.AddRead(ConstructServerResponseHeadersPacket(
+ 3, kServerDataStreamId1, false, false, GetResponseHeaders("200 OK"),
+ &server_header_offset));
+ mock_quic_data.AddRead(ConstructServerDataPacket(4, kClientDataStreamId1,
+ false, true, 0, "hello!"));
+ mock_quic_data.AddWrite(ConstructClientAckPacket(3, 4, 3, 1));
+ mock_quic_data.AddRead(ConstructServerDataPacket(
+ 5, kServerDataStreamId1, false, true, 0, "and hello!"));
+ mock_quic_data.AddWrite(
+ ConstructClientAckAndRstPacket(4, 4, QUIC_RST_ACKNOWLEDGEMENT, 5, 5, 1));
+ mock_quic_data.AddRead(ASYNC, ERR_IO_PENDING); // No more data to read
+ mock_quic_data.AddRead(ASYNC, 0); // EOF
+ mock_quic_data.AddSocketDataToFactory(&socket_factory_);
+
+ // The non-alternate protocol job needs to hang in order to guarantee that
+ // the alternate-protocol job will "win".
+ AddHangingNonAlternateProtocolSocketData();
+
+ CreateSession();
+
+ // PUSH_PROMISE handling in the http layer gets exercised here.
+ SendRequestAndExpectQuicResponse("hello!");
+
+ request_.url = GURL("https://mail.example.org/pushed.jpg");
+ SendRequestAndExpectQuicResponse("and hello!");
+
+ // Check that the NetLog was filled reasonably.
+ TestNetLogEntry::List entries;
+ net_log_.GetEntries(&entries);
+ EXPECT_LT(0u, entries.size());
+
+ // Check that we logged a QUIC_HTTP_STREAM_ADOPTED_PUSH_STREAM
+ int pos = ExpectLogContainsSomewhere(
+ entries, 0, NetLog::TYPE_QUIC_HTTP_STREAM_ADOPTED_PUSH_STREAM,
+ NetLog::PHASE_NONE);
+ EXPECT_LT(0, pos);
+}
+
class QuicNetworkTransactionWithDestinationTest
: public PlatformTest,
public ::testing::WithParamInterface<PoolingTestParams> {
« no previous file with comments | « net/quic/quic_chromium_client_stream.cc ('k') | net/quic/test_tools/quic_test_packet_maker.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698