diff options
author | rtenneti@chromium.org <rtenneti@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-01-16 15:58:14 +0000 |
---|---|---|
committer | rtenneti@chromium.org <rtenneti@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-01-16 15:58:14 +0000 |
commit | 9f0dcd4e2bff29c194036a4fad568d6c71f31000 (patch) | |
tree | c8ff26dc0c2be5a17e92d34aec6bac3220459572 /net/quic/quic_http_stream_test.cc | |
parent | 4be22f47f675ac89d6aafcbc88f9d391d9a82e03 (diff) | |
download | chromium_src-9f0dcd4e2bff29c194036a4fad568d6c71f31000.zip chromium_src-9f0dcd4e2bff29c194036a4fad568d6c71f31000.tar.gz chromium_src-9f0dcd4e2bff29c194036a4fad568d6c71f31000.tar.bz2 |
Land Recent QUIC Changes.
Eliminate separate boolean tracking socket writeability in
QuicConnection; query the writer instead. This CL tries to minimize
behavior changes, so no actual bugfixes. Connection will now check
writer's status instead of its local flag, so it will refuse to
write sooner.
Merge internal change: 59603011
https://codereview.chromium.org/138843003/
Change QUIC's SendAlgorithmInterface to have a separate UpdateRtt
method instead of passing it in with every acked packet.
This fixes a bug where the RTT was not being updated when
retransmitted packets were acked and one where a very large RTT could
be used when packets are acked before being sent.
Merge internal change: 59572874
https://codereview.chromium.org/138843003/
Break out of the loop in QuicSession::OnCanWrite if the QuicConnection
is congestion control blocked. This fixes a weird form of starvation
among same-priority streams caused by streams often ending up in the
same order in the WriteBlockedList before and after
QuicSession::OnCanWrite.
Stop iterating through QUIC write blocked streams if the connection is
congestion-control blocked to avoid starvation of same-priority
streams. Not flag protected.
Merge internal change: 59513911
https://codereview.chromium.org/139103002/
Fix a bug where the packet was put into unacked packets when it was
serialized and acked before being sent.
This was only ever seen on Chrome with very short RTTs.
Merge internal change: 59408566
https://codereview.chromium.org/133683010/
WriteBlockedList for QUIC that prioritizes Crypto and Headers streams
over data streams. Not flag protected.
Merge internal change: 59400238
https://codereview.chromium.org/137893008/
Create an interface for explicit notification of Dispatcher about
blocked writers; port TimeWaitListManager to the new interface.
Merge internal change: 59396227
https://codereview.chromium.org/138503006/
Remove WritePacket() from internal server's QuicDispatcher;
Integrating internal changes to clean up QuicDispatcher.
Merge internal change: 59346874
https://codereview.chromium.org/131743007/
Reset QUIC's retransmission counters whenever a new packet is acked
which updates the RTT estimate.
Previously the counters were only done when the left edge was acked,
which could cause excessive backoff when the connection was making
progress.
Merge internal change: 59292726
https://codereview.chromium.org/138273004/
Implement QuicPacketWriterWrapper. This lets us replace or embellish
the low-level writer without disturbing connections that keep a
pointer to the top level.
Merge internal change: 59287995
https://codereview.chromium.org/138273004/
Use basictypes.h consistenly in QUIC code instead of macros.h and/or
integral_types.h
Simply refactoring includes. Sync'ed with internal source code
for include of basictypes.h.
Merge internal change: 59287325
https://codereview.chromium.org/136853005/
Use the right priority when marking QUIC streams write blocked via
QuicFdWrapper::SetReady. Not flag protected.
Used NULL instead of nullptr.
Fixed QuicReliableClientStreamTests to pass. Activated the
QuicReliableClientStream in the QuicSession so that session's
MarkWriteBlocked knows about the stream.
Merge internal change: 59263642
https://codereview.chromium.org/136523005/
R=rch@chromium.org
Review URL: https://codereview.chromium.org/131743009
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@245204 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/quic/quic_http_stream_test.cc')
-rw-r--r-- | net/quic/quic_http_stream_test.cc | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/net/quic/quic_http_stream_test.cc b/net/quic/quic_http_stream_test.cc index 22ed3b8..a49d6bb 100644 --- a/net/quic/quic_http_stream_test.cc +++ b/net/quic/quic_http_stream_test.cc @@ -22,6 +22,7 @@ #include "net/quic/quic_default_packet_writer.h" #include "net/quic/quic_http_utils.h" #include "net/quic/quic_reliable_client_stream.h" +#include "net/quic/quic_write_blocked_list.h" #include "net/quic/spdy_utils.h" #include "net/quic/test_tools/mock_clock.h" #include "net/quic/test_tools/mock_crypto_client_stream_factory.h" @@ -35,7 +36,6 @@ #include "net/spdy/spdy_framer.h" #include "net/spdy/spdy_http_utils.h" #include "net/spdy/spdy_protocol.h" -#include "net/spdy/write_blocked_list.h" #include "testing/gmock/include/gmock/gmock.h" #include "testing/gtest/include/gtest/gtest.h" @@ -662,7 +662,7 @@ TEST_P(QuicHttpStreamTest, Priority) { QuicReliableClientStream* reliable_stream = QuicHttpStreamPeer::GetQuicReliableClientStream(stream_.get()); DCHECK(reliable_stream); - DCHECK_EQ(static_cast<QuicPriority>(kHighestPriority), + DCHECK_EQ(QuicWriteBlockedList::kHighestPriority, reliable_stream->EffectivePriority()); EXPECT_EQ(OK, stream_->SendRequest(headers_, &response_, @@ -709,13 +709,13 @@ TEST_P(QuicHttpStreamTest, CheckPriorityWithNoDelegate) { DCHECK(reliable_stream); QuicReliableClientStream::Delegate* delegate = reliable_stream->GetDelegate(); DCHECK(delegate); - DCHECK_EQ(static_cast<QuicPriority>(kHighestPriority), + DCHECK_EQ(QuicWriteBlockedList::kHighestPriority, reliable_stream->EffectivePriority()); // Set Delegate to NULL and make sure EffectivePriority returns highest // priority. reliable_stream->SetDelegate(NULL); - DCHECK_EQ(static_cast<QuicPriority>(kHighestPriority), + DCHECK_EQ(QuicWriteBlockedList::kHighestPriority, reliable_stream->EffectivePriority()); reliable_stream->SetDelegate(delegate); } |