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

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

Issue 573763003: client-only - Change QUIC clients to use the initial RTT estimate that (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@Increase_flow_control_receive_window_75381087
Patch Set: Created 6 years, 3 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_sent_packet_manager_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) 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 <stddef.h> 5 #include <stddef.h>
6 #include <string> 6 #include <string>
7 #include <sys/epoll.h> 7 #include <sys/epoll.h>
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/basictypes.h" 10 #include "base/basictypes.h"
(...skipping 925 matching lines...) Expand 10 before | Expand all | Expand 10 after
936 server_config_.set_max_streams_per_connection(2, 2); 936 server_config_.set_max_streams_per_connection(2, 2);
937 // Client tries to negotiate for 10. 937 // Client tries to negotiate for 10.
938 client_config_.set_max_streams_per_connection(10, 5); 938 client_config_.set_max_streams_per_connection(10, 5);
939 939
940 ASSERT_TRUE(Initialize()); 940 ASSERT_TRUE(Initialize());
941 client_->client()->WaitForCryptoHandshakeConfirmed(); 941 client_->client()->WaitForCryptoHandshakeConfirmed();
942 QuicConfig* client_negotiated_config = client_->client()->session()->config(); 942 QuicConfig* client_negotiated_config = client_->client()->session()->config();
943 EXPECT_EQ(2u, client_negotiated_config->max_streams_per_connection()); 943 EXPECT_EQ(2u, client_negotiated_config->max_streams_per_connection());
944 } 944 }
945 945
946 // TODO(rtenneti): DISABLED_LimitCongestionWindowAndRTT seems to be flaky. 946 TEST_P(EndToEndTest, LimitCongestionWindowAndRTT) {
947 // http://crbug.com/321870.
948 TEST_P(EndToEndTest, DISABLED_LimitCongestionWindowAndRTT) {
949 // Client tries to request twice the server's max initial window, and the 947 // Client tries to request twice the server's max initial window, and the
950 // server limits it to the max. 948 // server limits it to the max.
951 client_config_.SetInitialCongestionWindowToSend(2 * kMaxInitialWindow); 949 client_config_.SetInitialCongestionWindowToSend(2 * kMaxInitialWindow);
952 client_config_.SetInitialRoundTripTimeUsToSend(1); 950 client_config_.SetInitialRoundTripTimeUsToSend(1000);
953 951
954 ASSERT_TRUE(Initialize()); 952 ASSERT_TRUE(Initialize());
955 client_->client()->WaitForCryptoHandshakeConfirmed(); 953 client_->client()->WaitForCryptoHandshakeConfirmed();
956 server_thread_->WaitForCryptoHandshakeConfirmed(); 954 server_thread_->WaitForCryptoHandshakeConfirmed();
957 955
958 // Pause the server so we can access the server's internals without races. 956 // Pause the server so we can access the server's internals without races.
959 server_thread_->Pause(); 957 server_thread_->Pause();
960 QuicDispatcher* dispatcher = 958 QuicDispatcher* dispatcher =
961 QuicServerPeer::GetDispatcher(server_thread_->server()); 959 QuicServerPeer::GetDispatcher(server_thread_->server());
962 ASSERT_EQ(1u, dispatcher->session_map().size()); 960 ASSERT_EQ(1u, dispatcher->session_map().size());
963 const QuicSentPacketManager& client_sent_packet_manager = 961 const QuicSentPacketManager& client_sent_packet_manager =
964 client_->client()->session()->connection()->sent_packet_manager(); 962 client_->client()->session()->connection()->sent_packet_manager();
965 const QuicSentPacketManager& server_sent_packet_manager = 963 const QuicSentPacketManager& server_sent_packet_manager =
966 *GetSentPacketManagerFromFirstServerSession(); 964 *GetSentPacketManagerFromFirstServerSession();
967 965
968 // The client shouldn't set it's initial window based on the negotiated value. 966 // The client shouldn't set it's initial window based on the negotiated value.
969 EXPECT_EQ(kDefaultInitialWindow * kDefaultTCPMSS, 967 EXPECT_EQ(kDefaultInitialWindow * kDefaultTCPMSS,
970 client_sent_packet_manager.GetCongestionWindow()); 968 client_sent_packet_manager.GetCongestionWindow());
971 EXPECT_EQ(kMaxInitialWindow * kDefaultTCPMSS, 969 EXPECT_EQ(kMaxInitialWindow * kDefaultTCPMSS,
972 server_sent_packet_manager.GetCongestionWindow()); 970 server_sent_packet_manager.GetCongestionWindow());
973 971
974 EXPECT_EQ(GetParam().use_pacing, server_sent_packet_manager.using_pacing()); 972 EXPECT_EQ(GetParam().use_pacing, server_sent_packet_manager.using_pacing());
975 EXPECT_EQ(GetParam().use_pacing, client_sent_packet_manager.using_pacing()); 973 EXPECT_EQ(GetParam().use_pacing, client_sent_packet_manager.using_pacing());
976 974
977 EXPECT_EQ(100000u, 975 // The client *should* set the intitial RTT.
978 client_sent_packet_manager.GetRttStats()->initial_rtt_us()); 976 EXPECT_EQ(1000u, client_sent_packet_manager.GetRttStats()->initial_rtt_us());
979 EXPECT_EQ(1u, server_sent_packet_manager.GetRttStats()->initial_rtt_us()); 977 EXPECT_EQ(1000u, server_sent_packet_manager.GetRttStats()->initial_rtt_us());
980 978
981 // Now use the negotiated limits with packet loss. 979 // Now use the negotiated limits with packet loss.
982 SetPacketLossPercentage(30); 980 SetPacketLossPercentage(30);
983 981
984 // 10 KB body. 982 // 10 KB body.
985 string body; 983 string body;
986 GenerateBody(&body, 1024 * 10); 984 GenerateBody(&body, 1024 * 10);
987 985
988 HTTPMessage request(HttpConstants::HTTP_1_1, 986 HTTPMessage request(HttpConstants::HTTP_1_1,
989 HttpConstants::POST, "/foo"); 987 HttpConstants::POST, "/foo");
(...skipping 398 matching lines...) Expand 10 before | Expand all | Expand 10 after
1388 QuicSession* session = dispatcher->session_map().begin()->second; 1386 QuicSession* session = dispatcher->session_map().begin()->second;
1389 EXPECT_EQ(0u, QuicSessionPeer::GetLocallyClosedStreamsHighestOffset( 1387 EXPECT_EQ(0u, QuicSessionPeer::GetLocallyClosedStreamsHighestOffset(
1390 session).size()); 1388 session).size());
1391 server_thread_->Resume(); 1389 server_thread_->Resume();
1392 } 1390 }
1393 1391
1394 } // namespace 1392 } // namespace
1395 } // namespace test 1393 } // namespace test
1396 } // namespace tools 1394 } // namespace tools
1397 } // namespace net 1395 } // namespace net
OLDNEW
« no previous file with comments | « net/quic/quic_sent_packet_manager_test.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698