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

Side by Side Diff: net/quic/quic_connection_test.cc

Issue 2104633002: Landing recent QUIC changes until 6/24/2016 14:00 UTC (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 4 years, 5 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/quic/quic_connection.cc ('k') | net/quic/quic_crypto_client_stream_test.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/quic/quic_connection.h" 5 #include "net/quic/quic_connection.h"
6 6
7 #include <errno.h> 7 #include <errno.h>
8 #include <memory> 8 #include <memory>
9 #include <ostream> 9 #include <ostream>
10 #include <utility> 10 #include <utility>
(...skipping 1593 matching lines...) Expand 10 before | Expand all | Expand 10 after
1604 1604
1605 TEST_P(QuicConnectionTest, AckAll) { 1605 TEST_P(QuicConnectionTest, AckAll) {
1606 EXPECT_CALL(visitor_, OnSuccessfulVersionNegotiation(_)); 1606 EXPECT_CALL(visitor_, OnSuccessfulVersionNegotiation(_));
1607 ProcessPacket(kDefaultPathId, 1); 1607 ProcessPacket(kDefaultPathId, 1);
1608 1608
1609 QuicPacketCreatorPeer::SetPacketNumber(&peer_creator_, 1); 1609 QuicPacketCreatorPeer::SetPacketNumber(&peer_creator_, 1);
1610 QuicAckFrame frame1 = InitAckFrame(0); 1610 QuicAckFrame frame1 = InitAckFrame(0);
1611 ProcessAckPacket(&frame1); 1611 ProcessAckPacket(&frame1);
1612 } 1612 }
1613 1613
1614 TEST_P(QuicConnectionTest, SendingDifferentSequenceNumberLengthsBandwidth) {
1615 QuicPacketNumber last_packet;
1616 SendStreamDataToPeer(1, "foo", 0, !kFin, &last_packet);
1617 EXPECT_EQ(1u, last_packet);
1618 EXPECT_EQ(PACKET_1BYTE_PACKET_NUMBER,
1619 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1620 EXPECT_EQ(PACKET_1BYTE_PACKET_NUMBER,
1621 writer_->header().public_header.packet_number_length);
1622
1623 EXPECT_CALL(*send_algorithm_, GetCongestionWindow())
1624 .WillRepeatedly(Return(kMaxPacketSize * 256));
1625
1626 SendStreamDataToPeer(1, "bar", 3, !kFin, &last_packet);
1627 EXPECT_EQ(2u, last_packet);
1628 EXPECT_EQ(PACKET_2BYTE_PACKET_NUMBER,
1629 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1630 // The 1 packet lag is due to the packet number length being recalculated in
1631 // QuicConnection after a packet is sent.
1632 EXPECT_EQ(PACKET_1BYTE_PACKET_NUMBER,
1633 writer_->header().public_header.packet_number_length);
1634
1635 EXPECT_CALL(*send_algorithm_, GetCongestionWindow())
1636 .WillRepeatedly(Return(kMaxPacketSize * 256 * 256));
1637
1638 SendStreamDataToPeer(1, "foo", 6, !kFin, &last_packet);
1639 EXPECT_EQ(3u, last_packet);
1640 EXPECT_EQ(PACKET_4BYTE_PACKET_NUMBER,
1641 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1642 EXPECT_EQ(PACKET_2BYTE_PACKET_NUMBER,
1643 writer_->header().public_header.packet_number_length);
1644
1645 EXPECT_CALL(*send_algorithm_, GetCongestionWindow())
1646 .WillRepeatedly(Return(kMaxPacketSize * 256 * 256 * 256));
1647
1648 SendStreamDataToPeer(1, "bar", 9, !kFin, &last_packet);
1649 EXPECT_EQ(4u, last_packet);
1650 EXPECT_EQ(PACKET_4BYTE_PACKET_NUMBER,
1651 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1652 EXPECT_EQ(PACKET_4BYTE_PACKET_NUMBER,
1653 writer_->header().public_header.packet_number_length);
1654
1655 EXPECT_CALL(*send_algorithm_, GetCongestionWindow())
1656 .WillRepeatedly(Return(kMaxPacketSize * 256 * 256 * 256 * 256));
1657
1658 SendStreamDataToPeer(1, "foo", 12, !kFin, &last_packet);
1659 EXPECT_EQ(5u, last_packet);
1660 EXPECT_EQ(PACKET_6BYTE_PACKET_NUMBER,
1661 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1662 EXPECT_EQ(PACKET_4BYTE_PACKET_NUMBER,
1663 writer_->header().public_header.packet_number_length);
1664 }
1665
1666 // TODO(ianswett): Re-enable this test by finding a good way to test different
1667 // packet number lengths without sending packets with giant gaps.
1668 TEST_P(QuicConnectionTest,
1669 DISABLED_SendingDifferentSequenceNumberLengthsUnackedDelta) {
1670 QuicPacketNumber last_packet;
1671 SendStreamDataToPeer(1, "foo", 0, !kFin, &last_packet);
1672 EXPECT_EQ(1u, last_packet);
1673 EXPECT_EQ(PACKET_1BYTE_PACKET_NUMBER,
1674 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1675 EXPECT_EQ(PACKET_1BYTE_PACKET_NUMBER,
1676 writer_->header().public_header.packet_number_length);
1677
1678 QuicPacketCreatorPeer::SetPacketNumber(&peer_creator_, 100);
1679
1680 SendStreamDataToPeer(1, "bar", 3, !kFin, &last_packet);
1681 EXPECT_EQ(PACKET_2BYTE_PACKET_NUMBER,
1682 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1683 EXPECT_EQ(PACKET_1BYTE_PACKET_NUMBER,
1684 writer_->header().public_header.packet_number_length);
1685
1686 QuicPacketCreatorPeer::SetPacketNumber(&peer_creator_, 100 * 256);
1687
1688 SendStreamDataToPeer(1, "foo", 6, !kFin, &last_packet);
1689 EXPECT_EQ(PACKET_4BYTE_PACKET_NUMBER,
1690 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1691 EXPECT_EQ(PACKET_2BYTE_PACKET_NUMBER,
1692 writer_->header().public_header.packet_number_length);
1693
1694 QuicPacketCreatorPeer::SetPacketNumber(&peer_creator_, 100 * 256 * 256);
1695
1696 SendStreamDataToPeer(1, "bar", 9, !kFin, &last_packet);
1697 EXPECT_EQ(PACKET_4BYTE_PACKET_NUMBER,
1698 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1699 EXPECT_EQ(PACKET_4BYTE_PACKET_NUMBER,
1700 writer_->header().public_header.packet_number_length);
1701
1702 QuicPacketCreatorPeer::SetPacketNumber(&peer_creator_, 100 * 256 * 256 * 256);
1703
1704 SendStreamDataToPeer(1, "foo", 12, !kFin, &last_packet);
1705 EXPECT_EQ(PACKET_6BYTE_PACKET_NUMBER,
1706 QuicPacketCreatorPeer::NextPacketNumberLength(creator_));
1707 EXPECT_EQ(PACKET_4BYTE_PACKET_NUMBER,
1708 writer_->header().public_header.packet_number_length);
1709 }
1710
1711 TEST_P(QuicConnectionTest, BasicSending) { 1614 TEST_P(QuicConnectionTest, BasicSending) {
1712 EXPECT_CALL(visitor_, OnSuccessfulVersionNegotiation(_)); 1615 EXPECT_CALL(visitor_, OnSuccessfulVersionNegotiation(_));
1713 QuicPacketNumber last_packet; 1616 QuicPacketNumber last_packet;
1714 SendStreamDataToPeer(1, "foo", 0, !kFin, &last_packet); // Packet 1 1617 SendStreamDataToPeer(1, "foo", 0, !kFin, &last_packet); // Packet 1
1715 EXPECT_EQ(1u, last_packet); 1618 EXPECT_EQ(1u, last_packet);
1716 SendAckPacketToPeer(); // Packet 2 1619 SendAckPacketToPeer(); // Packet 2
1717 1620
1718 EXPECT_EQ(1u, least_unacked()); 1621 EXPECT_EQ(1u, least_unacked());
1719 1622
1720 SendAckPacketToPeer(); // Packet 3 1623 SendAckPacketToPeer(); // Packet 3
(...skipping 3314 matching lines...) Expand 10 before | Expand all | Expand 10 after
5035 // result in multiple attempts to close the connection - it will be marked as 4938 // result in multiple attempts to close the connection - it will be marked as
5036 // disconnected after the first call. 4939 // disconnected after the first call.
5037 EXPECT_CALL(visitor_, OnConnectionClosed(_, _, _)).Times(1); 4940 EXPECT_CALL(visitor_, OnConnectionClosed(_, _, _)).Times(1);
5038 connection_.CloseConnection(QUIC_NO_ERROR, "no reason", 4941 connection_.CloseConnection(QUIC_NO_ERROR, "no reason",
5039 ConnectionCloseBehavior::SILENT_CLOSE); 4942 ConnectionCloseBehavior::SILENT_CLOSE);
5040 connection_.CloseConnection(QUIC_NO_ERROR, "no reason", 4943 connection_.CloseConnection(QUIC_NO_ERROR, "no reason",
5041 ConnectionCloseBehavior::SILENT_CLOSE); 4944 ConnectionCloseBehavior::SILENT_CLOSE);
5042 } 4945 }
5043 4946
5044 TEST_P(QuicConnectionTest, ServerReceivesChloOnNonCryptoStream) { 4947 TEST_P(QuicConnectionTest, ServerReceivesChloOnNonCryptoStream) {
5045 FLAGS_quic_detect_memory_corrpution = true;
5046 EXPECT_CALL(visitor_, OnSuccessfulVersionNegotiation(_)); 4948 EXPECT_CALL(visitor_, OnSuccessfulVersionNegotiation(_));
5047 4949
5048 set_perspective(Perspective::IS_SERVER); 4950 set_perspective(Perspective::IS_SERVER);
5049 QuicPacketCreatorPeer::SetSendVersionInPacket(creator_, false); 4951 QuicPacketCreatorPeer::SetSendVersionInPacket(creator_, false);
5050 4952
5051 CryptoHandshakeMessage message; 4953 CryptoHandshakeMessage message;
5052 CryptoFramer framer; 4954 CryptoFramer framer;
5053 message.set_tag(kCHLO); 4955 message.set_tag(kCHLO);
5054 std::unique_ptr<QuicData> data(framer.ConstructHandshakeMessage(message)); 4956 std::unique_ptr<QuicData> data(framer.ConstructHandshakeMessage(message));
5055 frame1_.stream_id = 10; 4957 frame1_.stream_id = 10;
5056 frame1_.data_buffer = data->data(); 4958 frame1_.data_buffer = data->data();
5057 frame1_.data_length = data->length(); 4959 frame1_.data_length = data->length();
5058 4960
5059 EXPECT_CALL(visitor_, OnConnectionClosed(QUIC_MAYBE_CORRUPTED_MEMORY, _, 4961 EXPECT_CALL(visitor_, OnConnectionClosed(QUIC_MAYBE_CORRUPTED_MEMORY, _,
5060 ConnectionCloseSource::FROM_SELF)); 4962 ConnectionCloseSource::FROM_SELF));
5061 ProcessFramePacket(QuicFrame(&frame1_)); 4963 ProcessFramePacket(QuicFrame(&frame1_));
5062 } 4964 }
5063 4965
5064 TEST_P(QuicConnectionTest, ClientReceivesRejOnNonCryptoStream) { 4966 TEST_P(QuicConnectionTest, ClientReceivesRejOnNonCryptoStream) {
5065 FLAGS_quic_detect_memory_corrpution = true;
5066 EXPECT_CALL(visitor_, OnSuccessfulVersionNegotiation(_)); 4967 EXPECT_CALL(visitor_, OnSuccessfulVersionNegotiation(_));
5067 4968
5068 CryptoHandshakeMessage message; 4969 CryptoHandshakeMessage message;
5069 CryptoFramer framer; 4970 CryptoFramer framer;
5070 message.set_tag(kREJ); 4971 message.set_tag(kREJ);
5071 std::unique_ptr<QuicData> data(framer.ConstructHandshakeMessage(message)); 4972 std::unique_ptr<QuicData> data(framer.ConstructHandshakeMessage(message));
5072 frame1_.stream_id = 10; 4973 frame1_.stream_id = 10;
5073 frame1_.data_buffer = data->data(); 4974 frame1_.data_buffer = data->data();
5074 frame1_.data_length = data->length(); 4975 frame1_.data_length = data->length();
5075 4976
5076 EXPECT_CALL(visitor_, OnConnectionClosed(QUIC_MAYBE_CORRUPTED_MEMORY, _, 4977 EXPECT_CALL(visitor_, OnConnectionClosed(QUIC_MAYBE_CORRUPTED_MEMORY, _,
5077 ConnectionCloseSource::FROM_SELF)); 4978 ConnectionCloseSource::FROM_SELF));
5078 ProcessFramePacket(QuicFrame(&frame1_)); 4979 ProcessFramePacket(QuicFrame(&frame1_));
5079 } 4980 }
5080 4981
5081 } // namespace 4982 } // namespace
5082 } // namespace test 4983 } // namespace test
5083 } // namespace net 4984 } // namespace net
OLDNEW
« no previous file with comments | « net/quic/quic_connection.cc ('k') | net/quic/quic_crypto_client_stream_test.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698