Index: net/quic/quic_sent_packet_manager_test.cc |
diff --git a/net/quic/quic_sent_packet_manager_test.cc b/net/quic/quic_sent_packet_manager_test.cc |
index 3ab3e3964e847a161170b2efc4eeb4da2ee1278b..61240afe4bbd1eee4d12fc52006efd85d9e2768a 100644 |
--- a/net/quic/quic_sent_packet_manager_test.cc |
+++ b/net/quic/quic_sent_packet_manager_test.cc |
@@ -121,7 +121,7 @@ class QuicSentPacketManagerTest : public ::testing::TestWithParam<bool> { |
SerializedPacket CreatePacket(QuicPacketSequenceNumber sequence_number, |
bool retransmittable) { |
packets_.push_back(QuicPacket::NewDataPacket( |
- NULL, 1000, false, PACKET_8BYTE_GUID, false, |
+ NULL, 1000, false, PACKET_8BYTE_CONNECTION_ID, false, |
PACKET_6BYTE_SEQUENCE_NUMBER)); |
return SerializedPacket( |
sequence_number, PACKET_6BYTE_SEQUENCE_NUMBER, |
@@ -131,7 +131,7 @@ class QuicSentPacketManagerTest : public ::testing::TestWithParam<bool> { |
SerializedPacket CreateFecPacket(QuicPacketSequenceNumber sequence_number) { |
packets_.push_back(QuicPacket::NewFecPacket( |
- NULL, 1000, false, PACKET_8BYTE_GUID, false, |
+ NULL, 1000, false, PACKET_8BYTE_CONNECTION_ID, false, |
PACKET_6BYTE_SEQUENCE_NUMBER)); |
return SerializedPacket(sequence_number, PACKET_6BYTE_SEQUENCE_NUMBER, |
packets_.back(), 0u, NULL); |
@@ -1120,6 +1120,38 @@ TEST_F(QuicSentPacketManagerTest, GetTransmissionDelay) { |
} |
} |
+TEST_F(QuicSentPacketManagerTest, GetLossDelay) { |
+ MockLossAlgorithm* loss_algorithm = new MockLossAlgorithm(); |
+ QuicSentPacketManagerPeer::SetLossAlgorithm(&manager_, loss_algorithm); |
+ |
+ EXPECT_CALL(*loss_algorithm, GetLossTimeout()) |
+ .WillRepeatedly(Return(QuicTime::Zero())); |
+ SendDataPacket(1); |
+ SendDataPacket(2); |
+ |
+ // Handle an ack which causes the loss algorithm to be evaluated and |
+ // set the loss timeout. |
+ EXPECT_CALL(*send_algorithm_, UpdateRtt(_)); |
+ EXPECT_CALL(*send_algorithm_, OnPacketAcked(2, _)); |
+ EXPECT_CALL(*loss_algorithm, DetectLostPackets(_, _, _, _, _)) |
+ .WillOnce(Return(SequenceNumberSet())); |
+ ReceivedPacketInfo received_info; |
+ received_info.largest_observed = 2; |
+ received_info.missing_packets.insert(1); |
+ manager_.OnIncomingAck(received_info, clock_.Now()); |
+ |
+ QuicTime timeout(clock_.Now().Add(QuicTime::Delta::FromMilliseconds(10))); |
+ EXPECT_CALL(*loss_algorithm, GetLossTimeout()) |
+ .WillRepeatedly(Return(timeout)); |
+ EXPECT_EQ(timeout, manager_.GetRetransmissionTime()); |
+ |
+ // Fire the retransmission timeout and ensure the loss detection algorithm |
+ // is invoked. |
+ EXPECT_CALL(*loss_algorithm, DetectLostPackets(_, _, _, _, _)) |
+ .WillOnce(Return(SequenceNumberSet())); |
+ manager_.OnRetransmissionTimeout(); |
+} |
+ |
} // namespace |
} // namespace test |
} // namespace net |