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

Side by Side Diff: net/socket/client_socket_pool_base_unittest.cc

Issue 51683002: [Net] Assert that URLRequests with LOAD_IGNORE_LIMITS have MAXIMUM_PRIORITY (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 1 month 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 | Annotate | Revision Log
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/socket/client_socket_pool_base.h" 5 #include "net/socket/client_socket_pool_base.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/bind_helpers.h" 10 #include "base/bind_helpers.h"
(...skipping 27 matching lines...) Expand all
38 38
39 using ::testing::Invoke; 39 using ::testing::Invoke;
40 using ::testing::Return; 40 using ::testing::Return;
41 41
42 namespace net { 42 namespace net {
43 43
44 namespace { 44 namespace {
45 45
46 const int kDefaultMaxSockets = 4; 46 const int kDefaultMaxSockets = 4;
47 const int kDefaultMaxSocketsPerGroup = 2; 47 const int kDefaultMaxSocketsPerGroup = 2;
48 const net::RequestPriority kDefaultPriority = MEDIUM;
49 48
50 // Make sure |handle| sets load times correctly when it has been assigned a 49 // Make sure |handle| sets load times correctly when it has been assigned a
51 // reused socket. 50 // reused socket.
52 void TestLoadTimingInfoConnectedReused(const ClientSocketHandle& handle) { 51 void TestLoadTimingInfoConnectedReused(const ClientSocketHandle& handle) {
53 LoadTimingInfo load_timing_info; 52 LoadTimingInfo load_timing_info;
54 // Only pass true in as |is_reused|, as in general, HttpStream types should 53 // Only pass true in as |is_reused|, as in general, HttpStream types should
55 // have stricter concepts of reuse than socket pools. 54 // have stricter concepts of reuse than socket pools.
56 EXPECT_TRUE(handle.GetLoadTimingInfo(true, &load_timing_info)); 55 EXPECT_TRUE(handle.GetLoadTimingInfo(true, &load_timing_info));
57 56
58 EXPECT_EQ(true, load_timing_info.socket_reused); 57 EXPECT_EQ(true, load_timing_info.socket_reused);
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
91 LoadTimingInfo load_timing_info; 90 LoadTimingInfo load_timing_info;
92 EXPECT_FALSE(handle.GetLoadTimingInfo(false, &load_timing_info)); 91 EXPECT_FALSE(handle.GetLoadTimingInfo(false, &load_timing_info));
93 92
94 EXPECT_FALSE(load_timing_info.socket_reused); 93 EXPECT_FALSE(load_timing_info.socket_reused);
95 EXPECT_EQ(NetLog::Source::kInvalidId, load_timing_info.socket_log_id); 94 EXPECT_EQ(NetLog::Source::kInvalidId, load_timing_info.socket_log_id);
96 95
97 ExpectConnectTimingHasNoTimes(load_timing_info.connect_timing); 96 ExpectConnectTimingHasNoTimes(load_timing_info.connect_timing);
98 ExpectLoadTimingHasOnlyConnectionTimes(load_timing_info); 97 ExpectLoadTimingHasOnlyConnectionTimes(load_timing_info);
99 } 98 }
100 99
100 enum LimitsBehavior { IGNORE_LIMITS, RESPECT_LIMITS };
101
101 class TestSocketParams : public base::RefCounted<TestSocketParams> { 102 class TestSocketParams : public base::RefCounted<TestSocketParams> {
102 public: 103 public:
103 TestSocketParams() : ignore_limits_(false) {} 104 explicit TestSocketParams(LimitsBehavior behavior) : behavior_(behavior) {}
104 105
105 void set_ignore_limits(bool ignore_limits) { 106 bool ignore_limits() { return behavior_ == IGNORE_LIMITS; }
mmenke 2013/10/30 15:54:59 Why the change? Not strongly opposed, just doesn'
akalin 2013/10/30 23:32:16 Enum params are preferred over bool params in the
mmenke 2013/10/31 15:37:26 But we weren't passing around raw bools anywhere.
akalin 2013/11/01 07:02:47 Okay, done.
106 ignore_limits_ = ignore_limits;
107 }
108 bool ignore_limits() { return ignore_limits_; }
109 107
110 private: 108 private:
111 friend class base::RefCounted<TestSocketParams>; 109 friend class base::RefCounted<TestSocketParams>;
112 ~TestSocketParams() {} 110 ~TestSocketParams() {}
113 111
114 bool ignore_limits_; 112 LimitsBehavior behavior_;
115 }; 113 };
116 typedef ClientSocketPoolBase<TestSocketParams> TestClientSocketPoolBase; 114 typedef ClientSocketPoolBase<TestSocketParams> TestClientSocketPoolBase;
117 115
118 class MockClientSocket : public StreamSocket { 116 class MockClientSocket : public StreamSocket {
119 public: 117 public:
120 explicit MockClientSocket(net::NetLog* net_log) 118 explicit MockClientSocket(net::NetLog* net_log)
121 : connected_(false), 119 : connected_(false),
122 net_log_(BoundNetLog::Make(net_log, net::NetLog::SOURCE_SOCKET)), 120 net_log_(BoundNetLog::Make(net_log, net::NetLog::SOURCE_SOCKET)),
123 was_used_to_convey_data_(false) { 121 was_used_to_convey_data_(false) {
124 } 122 }
(...skipping 531 matching lines...) Expand 10 before | Expand all | Expand 10 after
656 654
657 private: 655 private:
658 bool have_result_; 656 bool have_result_;
659 bool waiting_for_result_; 657 bool waiting_for_result_;
660 int result_; 658 int result_;
661 }; 659 };
662 660
663 class ClientSocketPoolBaseTest : public testing::Test { 661 class ClientSocketPoolBaseTest : public testing::Test {
664 protected: 662 protected:
665 ClientSocketPoolBaseTest() 663 ClientSocketPoolBaseTest()
666 : params_(new TestSocketParams()), 664 : params_(new TestSocketParams(RESPECT_LIMITS)),
667 histograms_("ClientSocketPoolTest") { 665 histograms_("ClientSocketPoolTest") {
668 connect_backup_jobs_enabled_ = 666 connect_backup_jobs_enabled_ =
669 internal::ClientSocketPoolBaseHelper::connect_backup_jobs_enabled(); 667 internal::ClientSocketPoolBaseHelper::connect_backup_jobs_enabled();
670 internal::ClientSocketPoolBaseHelper::set_connect_backup_jobs_enabled(true); 668 internal::ClientSocketPoolBaseHelper::set_connect_backup_jobs_enabled(true);
671 cleanup_timer_enabled_ = 669 cleanup_timer_enabled_ =
672 internal::ClientSocketPoolBaseHelper::cleanup_timer_enabled(); 670 internal::ClientSocketPoolBaseHelper::cleanup_timer_enabled();
673 } 671 }
674 672
675 virtual ~ClientSocketPoolBaseTest() { 673 virtual ~ClientSocketPoolBaseTest() {
676 internal::ClientSocketPoolBaseHelper::set_connect_backup_jobs_enabled( 674 internal::ClientSocketPoolBaseHelper::set_connect_backup_jobs_enabled(
(...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after
741 scoped_ptr<TestClientSocketPool> pool_; 739 scoped_ptr<TestClientSocketPool> pool_;
742 ClientSocketPoolTest test_base_; 740 ClientSocketPoolTest test_base_;
743 }; 741 };
744 742
745 // Even though a timeout is specified, it doesn't time out on a synchronous 743 // Even though a timeout is specified, it doesn't time out on a synchronous
746 // completion. 744 // completion.
747 TEST_F(ClientSocketPoolBaseTest, ConnectJob_NoTimeoutOnSynchronousCompletion) { 745 TEST_F(ClientSocketPoolBaseTest, ConnectJob_NoTimeoutOnSynchronousCompletion) {
748 TestConnectJobDelegate delegate; 746 TestConnectJobDelegate delegate;
749 ClientSocketHandle ignored; 747 ClientSocketHandle ignored;
750 TestClientSocketPoolBase::Request request( 748 TestClientSocketPoolBase::Request request(
751 &ignored, CompletionCallback(), kDefaultPriority, 749 &ignored, CompletionCallback(), DEFAULT_PRIORITY,
752 internal::ClientSocketPoolBaseHelper::NORMAL, 750 internal::ClientSocketPoolBaseHelper::NORMAL,
753 false, params_, BoundNetLog()); 751 false, params_, BoundNetLog());
754 scoped_ptr<TestConnectJob> job( 752 scoped_ptr<TestConnectJob> job(
755 new TestConnectJob(TestConnectJob::kMockJob, 753 new TestConnectJob(TestConnectJob::kMockJob,
756 "a", 754 "a",
757 request, 755 request,
758 base::TimeDelta::FromMicroseconds(1), 756 base::TimeDelta::FromMicroseconds(1),
759 &delegate, 757 &delegate,
760 &client_socket_factory_, 758 &client_socket_factory_,
761 NULL)); 759 NULL));
762 EXPECT_EQ(OK, job->Connect()); 760 EXPECT_EQ(OK, job->Connect());
763 } 761 }
764 762
765 TEST_F(ClientSocketPoolBaseTest, ConnectJob_TimedOut) { 763 TEST_F(ClientSocketPoolBaseTest, ConnectJob_TimedOut) {
766 TestConnectJobDelegate delegate; 764 TestConnectJobDelegate delegate;
767 ClientSocketHandle ignored; 765 ClientSocketHandle ignored;
768 CapturingNetLog log; 766 CapturingNetLog log;
769 767
770 TestClientSocketPoolBase::Request request( 768 TestClientSocketPoolBase::Request request(
771 &ignored, CompletionCallback(), kDefaultPriority, 769 &ignored, CompletionCallback(), DEFAULT_PRIORITY,
772 internal::ClientSocketPoolBaseHelper::NORMAL, 770 internal::ClientSocketPoolBaseHelper::NORMAL,
773 false, params_, BoundNetLog()); 771 false, params_, BoundNetLog());
774 // Deleted by TestConnectJobDelegate. 772 // Deleted by TestConnectJobDelegate.
775 TestConnectJob* job = 773 TestConnectJob* job =
776 new TestConnectJob(TestConnectJob::kMockPendingJob, 774 new TestConnectJob(TestConnectJob::kMockPendingJob,
777 "a", 775 "a",
778 request, 776 request,
779 base::TimeDelta::FromMicroseconds(1), 777 base::TimeDelta::FromMicroseconds(1),
780 &delegate, 778 &delegate,
781 &client_socket_factory_, 779 &client_socket_factory_,
(...skipping 26 matching lines...) Expand all
808 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 806 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
809 807
810 TestCompletionCallback callback; 808 TestCompletionCallback callback;
811 ClientSocketHandle handle; 809 ClientSocketHandle handle;
812 CapturingBoundNetLog log; 810 CapturingBoundNetLog log;
813 TestLoadTimingInfoNotConnected(handle); 811 TestLoadTimingInfoNotConnected(handle);
814 812
815 EXPECT_EQ(OK, 813 EXPECT_EQ(OK,
816 handle.Init("a", 814 handle.Init("a",
817 params_, 815 params_,
818 kDefaultPriority, 816 DEFAULT_PRIORITY,
819 callback.callback(), 817 callback.callback(),
820 pool_.get(), 818 pool_.get(),
821 log.bound())); 819 log.bound()));
822 EXPECT_TRUE(handle.is_initialized()); 820 EXPECT_TRUE(handle.is_initialized());
823 EXPECT_TRUE(handle.socket()); 821 EXPECT_TRUE(handle.socket());
824 TestLoadTimingInfoConnectedNotReused(handle); 822 TestLoadTimingInfoConnectedNotReused(handle);
825 823
826 handle.Reset(); 824 handle.Reset();
827 TestLoadTimingInfoNotConnected(handle); 825 TestLoadTimingInfoNotConnected(handle);
828 826
(...skipping 22 matching lines...) Expand all
851 ClientSocketHandle handle; 849 ClientSocketHandle handle;
852 TestCompletionCallback callback; 850 TestCompletionCallback callback;
853 // Set the additional error state members to ensure that they get cleared. 851 // Set the additional error state members to ensure that they get cleared.
854 handle.set_is_ssl_error(true); 852 handle.set_is_ssl_error(true);
855 HttpResponseInfo info; 853 HttpResponseInfo info;
856 info.headers = new HttpResponseHeaders(std::string()); 854 info.headers = new HttpResponseHeaders(std::string());
857 handle.set_ssl_error_response_info(info); 855 handle.set_ssl_error_response_info(info);
858 EXPECT_EQ(ERR_CONNECTION_FAILED, 856 EXPECT_EQ(ERR_CONNECTION_FAILED,
859 handle.Init("a", 857 handle.Init("a",
860 params_, 858 params_,
861 kDefaultPriority, 859 DEFAULT_PRIORITY,
862 callback.callback(), 860 callback.callback(),
863 pool_.get(), 861 pool_.get(),
864 log.bound())); 862 log.bound()));
865 EXPECT_FALSE(handle.socket()); 863 EXPECT_FALSE(handle.socket());
866 EXPECT_FALSE(handle.is_ssl_error()); 864 EXPECT_FALSE(handle.is_ssl_error());
867 EXPECT_TRUE(handle.ssl_error_response_info().headers.get() == NULL); 865 EXPECT_TRUE(handle.ssl_error_response_info().headers.get() == NULL);
868 TestLoadTimingInfoNotConnected(handle); 866 TestLoadTimingInfoNotConnected(handle);
869 867
870 CapturingNetLog::CapturedEntryList entries; 868 CapturingNetLog::CapturedEntryList entries;
871 log.GetEntries(&entries); 869 log.GetEntries(&entries);
872 870
873 EXPECT_EQ(3u, entries.size()); 871 EXPECT_EQ(3u, entries.size());
874 EXPECT_TRUE(LogContainsBeginEvent( 872 EXPECT_TRUE(LogContainsBeginEvent(
875 entries, 0, NetLog::TYPE_SOCKET_POOL)); 873 entries, 0, NetLog::TYPE_SOCKET_POOL));
876 EXPECT_TRUE(LogContainsEvent( 874 EXPECT_TRUE(LogContainsEvent(
877 entries, 1, NetLog::TYPE_SOCKET_POOL_BOUND_TO_CONNECT_JOB, 875 entries, 1, NetLog::TYPE_SOCKET_POOL_BOUND_TO_CONNECT_JOB,
878 NetLog::PHASE_NONE)); 876 NetLog::PHASE_NONE));
879 EXPECT_TRUE(LogContainsEndEvent( 877 EXPECT_TRUE(LogContainsEndEvent(
880 entries, 2, NetLog::TYPE_SOCKET_POOL)); 878 entries, 2, NetLog::TYPE_SOCKET_POOL));
881 } 879 }
882 880
883 TEST_F(ClientSocketPoolBaseTest, TotalLimit) { 881 TEST_F(ClientSocketPoolBaseTest, TotalLimit) {
884 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 882 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
885 883
886 // TODO(eroman): Check that the NetLog contains this event. 884 // TODO(eroman): Check that the NetLog contains this event.
887 885
888 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 886 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
889 EXPECT_EQ(OK, StartRequest("b", kDefaultPriority)); 887 EXPECT_EQ(OK, StartRequest("b", DEFAULT_PRIORITY));
890 EXPECT_EQ(OK, StartRequest("c", kDefaultPriority)); 888 EXPECT_EQ(OK, StartRequest("c", DEFAULT_PRIORITY));
891 EXPECT_EQ(OK, StartRequest("d", kDefaultPriority)); 889 EXPECT_EQ(OK, StartRequest("d", DEFAULT_PRIORITY));
892 890
893 EXPECT_EQ(static_cast<int>(requests_size()), 891 EXPECT_EQ(static_cast<int>(requests_size()),
894 client_socket_factory_.allocation_count()); 892 client_socket_factory_.allocation_count());
895 EXPECT_EQ(requests_size() - kDefaultMaxSockets, completion_count()); 893 EXPECT_EQ(requests_size() - kDefaultMaxSockets, completion_count());
896 894
897 EXPECT_EQ(ERR_IO_PENDING, StartRequest("e", kDefaultPriority)); 895 EXPECT_EQ(ERR_IO_PENDING, StartRequest("e", DEFAULT_PRIORITY));
898 EXPECT_EQ(ERR_IO_PENDING, StartRequest("f", kDefaultPriority)); 896 EXPECT_EQ(ERR_IO_PENDING, StartRequest("f", DEFAULT_PRIORITY));
899 EXPECT_EQ(ERR_IO_PENDING, StartRequest("g", kDefaultPriority)); 897 EXPECT_EQ(ERR_IO_PENDING, StartRequest("g", DEFAULT_PRIORITY));
900 898
901 ReleaseAllConnections(ClientSocketPoolTest::NO_KEEP_ALIVE); 899 ReleaseAllConnections(ClientSocketPoolTest::NO_KEEP_ALIVE);
902 900
903 EXPECT_EQ(static_cast<int>(requests_size()), 901 EXPECT_EQ(static_cast<int>(requests_size()),
904 client_socket_factory_.allocation_count()); 902 client_socket_factory_.allocation_count());
905 EXPECT_EQ(requests_size() - kDefaultMaxSockets, completion_count()); 903 EXPECT_EQ(requests_size() - kDefaultMaxSockets, completion_count());
906 904
907 EXPECT_EQ(1, GetOrderOfRequest(1)); 905 EXPECT_EQ(1, GetOrderOfRequest(1));
908 EXPECT_EQ(2, GetOrderOfRequest(2)); 906 EXPECT_EQ(2, GetOrderOfRequest(2));
909 EXPECT_EQ(3, GetOrderOfRequest(3)); 907 EXPECT_EQ(3, GetOrderOfRequest(3));
910 EXPECT_EQ(4, GetOrderOfRequest(4)); 908 EXPECT_EQ(4, GetOrderOfRequest(4));
911 EXPECT_EQ(5, GetOrderOfRequest(5)); 909 EXPECT_EQ(5, GetOrderOfRequest(5));
912 EXPECT_EQ(6, GetOrderOfRequest(6)); 910 EXPECT_EQ(6, GetOrderOfRequest(6));
913 EXPECT_EQ(7, GetOrderOfRequest(7)); 911 EXPECT_EQ(7, GetOrderOfRequest(7));
914 912
915 // Make sure we test order of all requests made. 913 // Make sure we test order of all requests made.
916 EXPECT_EQ(ClientSocketPoolTest::kIndexOutOfBounds, GetOrderOfRequest(8)); 914 EXPECT_EQ(ClientSocketPoolTest::kIndexOutOfBounds, GetOrderOfRequest(8));
917 } 915 }
918 916
919 TEST_F(ClientSocketPoolBaseTest, TotalLimitReachedNewGroup) { 917 TEST_F(ClientSocketPoolBaseTest, TotalLimitReachedNewGroup) {
920 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 918 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
921 919
922 // TODO(eroman): Check that the NetLog contains this event. 920 // TODO(eroman): Check that the NetLog contains this event.
923 921
924 // Reach all limits: max total sockets, and max sockets per group. 922 // Reach all limits: max total sockets, and max sockets per group.
925 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 923 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
926 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 924 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
927 EXPECT_EQ(OK, StartRequest("b", kDefaultPriority)); 925 EXPECT_EQ(OK, StartRequest("b", DEFAULT_PRIORITY));
928 EXPECT_EQ(OK, StartRequest("b", kDefaultPriority)); 926 EXPECT_EQ(OK, StartRequest("b", DEFAULT_PRIORITY));
929 927
930 EXPECT_EQ(static_cast<int>(requests_size()), 928 EXPECT_EQ(static_cast<int>(requests_size()),
931 client_socket_factory_.allocation_count()); 929 client_socket_factory_.allocation_count());
932 EXPECT_EQ(requests_size() - kDefaultMaxSockets, completion_count()); 930 EXPECT_EQ(requests_size() - kDefaultMaxSockets, completion_count());
933 931
934 // Now create a new group and verify that we don't starve it. 932 // Now create a new group and verify that we don't starve it.
935 EXPECT_EQ(ERR_IO_PENDING, StartRequest("c", kDefaultPriority)); 933 EXPECT_EQ(ERR_IO_PENDING, StartRequest("c", DEFAULT_PRIORITY));
936 934
937 ReleaseAllConnections(ClientSocketPoolTest::NO_KEEP_ALIVE); 935 ReleaseAllConnections(ClientSocketPoolTest::NO_KEEP_ALIVE);
938 936
939 EXPECT_EQ(static_cast<int>(requests_size()), 937 EXPECT_EQ(static_cast<int>(requests_size()),
940 client_socket_factory_.allocation_count()); 938 client_socket_factory_.allocation_count());
941 EXPECT_EQ(requests_size() - kDefaultMaxSockets, completion_count()); 939 EXPECT_EQ(requests_size() - kDefaultMaxSockets, completion_count());
942 940
943 EXPECT_EQ(1, GetOrderOfRequest(1)); 941 EXPECT_EQ(1, GetOrderOfRequest(1));
944 EXPECT_EQ(2, GetOrderOfRequest(2)); 942 EXPECT_EQ(2, GetOrderOfRequest(2));
945 EXPECT_EQ(3, GetOrderOfRequest(3)); 943 EXPECT_EQ(3, GetOrderOfRequest(3));
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after
1021 EXPECT_EQ(7, GetOrderOfRequest(7)); 1019 EXPECT_EQ(7, GetOrderOfRequest(7));
1022 1020
1023 // Make sure we test order of all requests made. 1021 // Make sure we test order of all requests made.
1024 EXPECT_EQ(ClientSocketPoolTest::kIndexOutOfBounds, GetOrderOfRequest(8)); 1022 EXPECT_EQ(ClientSocketPoolTest::kIndexOutOfBounds, GetOrderOfRequest(8));
1025 } 1023 }
1026 1024
1027 // Make sure that we count connecting sockets against the total limit. 1025 // Make sure that we count connecting sockets against the total limit.
1028 TEST_F(ClientSocketPoolBaseTest, TotalLimitCountsConnectingSockets) { 1026 TEST_F(ClientSocketPoolBaseTest, TotalLimitCountsConnectingSockets) {
1029 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1027 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1030 1028
1031 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1029 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1032 EXPECT_EQ(OK, StartRequest("b", kDefaultPriority)); 1030 EXPECT_EQ(OK, StartRequest("b", DEFAULT_PRIORITY));
1033 EXPECT_EQ(OK, StartRequest("c", kDefaultPriority)); 1031 EXPECT_EQ(OK, StartRequest("c", DEFAULT_PRIORITY));
1034 1032
1035 // Create one asynchronous request. 1033 // Create one asynchronous request.
1036 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1034 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1037 EXPECT_EQ(ERR_IO_PENDING, StartRequest("d", kDefaultPriority)); 1035 EXPECT_EQ(ERR_IO_PENDING, StartRequest("d", DEFAULT_PRIORITY));
1038 1036
1039 // We post all of our delayed tasks with a 2ms delay. I.e. they don't 1037 // We post all of our delayed tasks with a 2ms delay. I.e. they don't
1040 // actually become pending until 2ms after they have been created. In order 1038 // actually become pending until 2ms after they have been created. In order
1041 // to flush all tasks, we need to wait so that we know there are no 1039 // to flush all tasks, we need to wait so that we know there are no
1042 // soon-to-be-pending tasks waiting. 1040 // soon-to-be-pending tasks waiting.
1043 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(10)); 1041 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(10));
1044 base::MessageLoop::current()->RunUntilIdle(); 1042 base::MessageLoop::current()->RunUntilIdle();
1045 1043
1046 // The next synchronous request should wait for its turn. 1044 // The next synchronous request should wait for its turn.
1047 connect_job_factory_->set_job_type(TestConnectJob::kMockJob); 1045 connect_job_factory_->set_job_type(TestConnectJob::kMockJob);
1048 EXPECT_EQ(ERR_IO_PENDING, StartRequest("e", kDefaultPriority)); 1046 EXPECT_EQ(ERR_IO_PENDING, StartRequest("e", DEFAULT_PRIORITY));
1049 1047
1050 ReleaseAllConnections(ClientSocketPoolTest::NO_KEEP_ALIVE); 1048 ReleaseAllConnections(ClientSocketPoolTest::NO_KEEP_ALIVE);
1051 1049
1052 EXPECT_EQ(static_cast<int>(requests_size()), 1050 EXPECT_EQ(static_cast<int>(requests_size()),
1053 client_socket_factory_.allocation_count()); 1051 client_socket_factory_.allocation_count());
1054 1052
1055 EXPECT_EQ(1, GetOrderOfRequest(1)); 1053 EXPECT_EQ(1, GetOrderOfRequest(1));
1056 EXPECT_EQ(2, GetOrderOfRequest(2)); 1054 EXPECT_EQ(2, GetOrderOfRequest(2));
1057 EXPECT_EQ(3, GetOrderOfRequest(3)); 1055 EXPECT_EQ(3, GetOrderOfRequest(3));
1058 EXPECT_EQ(4, GetOrderOfRequest(4)); 1056 EXPECT_EQ(4, GetOrderOfRequest(4));
1059 EXPECT_EQ(5, GetOrderOfRequest(5)); 1057 EXPECT_EQ(5, GetOrderOfRequest(5));
1060 1058
1061 // Make sure we test order of all requests made. 1059 // Make sure we test order of all requests made.
1062 EXPECT_EQ(ClientSocketPoolTest::kIndexOutOfBounds, GetOrderOfRequest(6)); 1060 EXPECT_EQ(ClientSocketPoolTest::kIndexOutOfBounds, GetOrderOfRequest(6));
1063 } 1061 }
1064 1062
1065 TEST_F(ClientSocketPoolBaseTest, CorrectlyCountStalledGroups) { 1063 TEST_F(ClientSocketPoolBaseTest, CorrectlyCountStalledGroups) {
1066 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets); 1064 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets);
1067 connect_job_factory_->set_job_type(TestConnectJob::kMockJob); 1065 connect_job_factory_->set_job_type(TestConnectJob::kMockJob);
1068 1066
1069 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1067 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1070 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1068 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1071 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1069 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1072 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1070 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1073 1071
1074 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 1072 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
1075 1073
1076 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count()); 1074 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count());
1077 1075
1078 EXPECT_EQ(ERR_IO_PENDING, StartRequest("b", kDefaultPriority)); 1076 EXPECT_EQ(ERR_IO_PENDING, StartRequest("b", DEFAULT_PRIORITY));
1079 EXPECT_EQ(ERR_IO_PENDING, StartRequest("c", kDefaultPriority)); 1077 EXPECT_EQ(ERR_IO_PENDING, StartRequest("c", DEFAULT_PRIORITY));
1080 1078
1081 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count()); 1079 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count());
1082 1080
1083 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE)); 1081 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE));
1084 EXPECT_EQ(kDefaultMaxSockets + 1, client_socket_factory_.allocation_count()); 1082 EXPECT_EQ(kDefaultMaxSockets + 1, client_socket_factory_.allocation_count());
1085 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE)); 1083 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE));
1086 EXPECT_EQ(kDefaultMaxSockets + 2, client_socket_factory_.allocation_count()); 1084 EXPECT_EQ(kDefaultMaxSockets + 2, client_socket_factory_.allocation_count());
1087 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE)); 1085 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE));
1088 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE)); 1086 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE));
1089 EXPECT_EQ(kDefaultMaxSockets + 2, client_socket_factory_.allocation_count()); 1087 EXPECT_EQ(kDefaultMaxSockets + 2, client_socket_factory_.allocation_count());
1090 } 1088 }
1091 1089
1092 TEST_F(ClientSocketPoolBaseTest, StallAndThenCancelAndTriggerAvailableSocket) { 1090 TEST_F(ClientSocketPoolBaseTest, StallAndThenCancelAndTriggerAvailableSocket) {
1093 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets); 1091 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets);
1094 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1092 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1095 1093
1096 ClientSocketHandle handle; 1094 ClientSocketHandle handle;
1097 TestCompletionCallback callback; 1095 TestCompletionCallback callback;
1098 EXPECT_EQ(ERR_IO_PENDING, 1096 EXPECT_EQ(ERR_IO_PENDING,
1099 handle.Init("a", 1097 handle.Init("a",
1100 params_, 1098 params_,
1101 kDefaultPriority, 1099 DEFAULT_PRIORITY,
1102 callback.callback(), 1100 callback.callback(),
1103 pool_.get(), 1101 pool_.get(),
1104 BoundNetLog())); 1102 BoundNetLog()));
1105 1103
1106 ClientSocketHandle handles[4]; 1104 ClientSocketHandle handles[4];
1107 for (size_t i = 0; i < arraysize(handles); ++i) { 1105 for (size_t i = 0; i < arraysize(handles); ++i) {
1108 TestCompletionCallback callback; 1106 TestCompletionCallback callback;
1109 EXPECT_EQ(ERR_IO_PENDING, 1107 EXPECT_EQ(ERR_IO_PENDING,
1110 handles[i].Init("b", 1108 handles[i].Init("b",
1111 params_, 1109 params_,
1112 kDefaultPriority, 1110 DEFAULT_PRIORITY,
1113 callback.callback(), 1111 callback.callback(),
1114 pool_.get(), 1112 pool_.get(),
1115 BoundNetLog())); 1113 BoundNetLog()));
1116 } 1114 }
1117 1115
1118 // One will be stalled, cancel all the handles now. 1116 // One will be stalled, cancel all the handles now.
1119 // This should hit the OnAvailableSocketSlot() code where we previously had 1117 // This should hit the OnAvailableSocketSlot() code where we previously had
1120 // stalled groups, but no longer have any. 1118 // stalled groups, but no longer have any.
1121 for (size_t i = 0; i < arraysize(handles); ++i) 1119 for (size_t i = 0; i < arraysize(handles); ++i)
1122 handles[i].Reset(); 1120 handles[i].Reset();
1123 } 1121 }
1124 1122
1125 TEST_F(ClientSocketPoolBaseTest, CancelStalledSocketAtSocketLimit) { 1123 TEST_F(ClientSocketPoolBaseTest, CancelStalledSocketAtSocketLimit) {
1126 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1124 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1127 connect_job_factory_->set_job_type(TestConnectJob::kMockJob); 1125 connect_job_factory_->set_job_type(TestConnectJob::kMockJob);
1128 1126
1129 { 1127 {
1130 ClientSocketHandle handles[kDefaultMaxSockets]; 1128 ClientSocketHandle handles[kDefaultMaxSockets];
1131 TestCompletionCallback callbacks[kDefaultMaxSockets]; 1129 TestCompletionCallback callbacks[kDefaultMaxSockets];
1132 for (int i = 0; i < kDefaultMaxSockets; ++i) { 1130 for (int i = 0; i < kDefaultMaxSockets; ++i) {
1133 EXPECT_EQ(OK, handles[i].Init(base::IntToString(i), 1131 EXPECT_EQ(OK, handles[i].Init(base::IntToString(i),
1134 params_, 1132 params_,
1135 kDefaultPriority, 1133 DEFAULT_PRIORITY,
1136 callbacks[i].callback(), 1134 callbacks[i].callback(),
1137 pool_.get(), 1135 pool_.get(),
1138 BoundNetLog())); 1136 BoundNetLog()));
1139 } 1137 }
1140 1138
1141 // Force a stalled group. 1139 // Force a stalled group.
1142 ClientSocketHandle stalled_handle; 1140 ClientSocketHandle stalled_handle;
1143 TestCompletionCallback callback; 1141 TestCompletionCallback callback;
1144 EXPECT_EQ(ERR_IO_PENDING, stalled_handle.Init("foo", 1142 EXPECT_EQ(ERR_IO_PENDING, stalled_handle.Init("foo",
1145 params_, 1143 params_,
1146 kDefaultPriority, 1144 DEFAULT_PRIORITY,
1147 callback.callback(), 1145 callback.callback(),
1148 pool_.get(), 1146 pool_.get(),
1149 BoundNetLog())); 1147 BoundNetLog()));
1150 1148
1151 // Cancel the stalled request. 1149 // Cancel the stalled request.
1152 stalled_handle.Reset(); 1150 stalled_handle.Reset();
1153 1151
1154 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count()); 1152 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count());
1155 EXPECT_EQ(0, pool_->IdleSocketCount()); 1153 EXPECT_EQ(0, pool_->IdleSocketCount());
1156 1154
1157 // Dropping out of scope will close all handles and return them to idle. 1155 // Dropping out of scope will close all handles and return them to idle.
1158 } 1156 }
1159 1157
1160 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count()); 1158 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count());
1161 EXPECT_EQ(kDefaultMaxSockets, pool_->IdleSocketCount()); 1159 EXPECT_EQ(kDefaultMaxSockets, pool_->IdleSocketCount());
1162 } 1160 }
1163 1161
1164 TEST_F(ClientSocketPoolBaseTest, CancelPendingSocketAtSocketLimit) { 1162 TEST_F(ClientSocketPoolBaseTest, CancelPendingSocketAtSocketLimit) {
1165 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1163 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1166 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 1164 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
1167 1165
1168 { 1166 {
1169 ClientSocketHandle handles[kDefaultMaxSockets]; 1167 ClientSocketHandle handles[kDefaultMaxSockets];
1170 for (int i = 0; i < kDefaultMaxSockets; ++i) { 1168 for (int i = 0; i < kDefaultMaxSockets; ++i) {
1171 TestCompletionCallback callback; 1169 TestCompletionCallback callback;
1172 EXPECT_EQ(ERR_IO_PENDING, handles[i].Init(base::IntToString(i), 1170 EXPECT_EQ(ERR_IO_PENDING, handles[i].Init(base::IntToString(i),
1173 params_, 1171 params_,
1174 kDefaultPriority, 1172 DEFAULT_PRIORITY,
1175 callback.callback(), 1173 callback.callback(),
1176 pool_.get(), 1174 pool_.get(),
1177 BoundNetLog())); 1175 BoundNetLog()));
1178 } 1176 }
1179 1177
1180 // Force a stalled group. 1178 // Force a stalled group.
1181 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1179 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1182 ClientSocketHandle stalled_handle; 1180 ClientSocketHandle stalled_handle;
1183 TestCompletionCallback callback; 1181 TestCompletionCallback callback;
1184 EXPECT_EQ(ERR_IO_PENDING, stalled_handle.Init("foo", 1182 EXPECT_EQ(ERR_IO_PENDING, stalled_handle.Init("foo",
1185 params_, 1183 params_,
1186 kDefaultPriority, 1184 DEFAULT_PRIORITY,
1187 callback.callback(), 1185 callback.callback(),
1188 pool_.get(), 1186 pool_.get(),
1189 BoundNetLog())); 1187 BoundNetLog()));
1190 1188
1191 // Since it is stalled, it should have no connect jobs. 1189 // Since it is stalled, it should have no connect jobs.
1192 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("foo")); 1190 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("foo"));
1193 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("foo")); 1191 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("foo"));
1194 1192
1195 // Cancel the stalled request. 1193 // Cancel the stalled request.
1196 handles[0].Reset(); 1194 handles[0].Reset();
(...skipping 24 matching lines...) Expand all
1221 ClientSocketHandle stalled_handle; 1219 ClientSocketHandle stalled_handle;
1222 TestCompletionCallback callback; 1220 TestCompletionCallback callback;
1223 { 1221 {
1224 EXPECT_FALSE(pool_->IsStalled()); 1222 EXPECT_FALSE(pool_->IsStalled());
1225 ClientSocketHandle handles[kDefaultMaxSockets]; 1223 ClientSocketHandle handles[kDefaultMaxSockets];
1226 for (int i = 0; i < kDefaultMaxSockets; ++i) { 1224 for (int i = 0; i < kDefaultMaxSockets; ++i) {
1227 TestCompletionCallback callback; 1225 TestCompletionCallback callback;
1228 EXPECT_EQ(OK, handles[i].Init(base::StringPrintf( 1226 EXPECT_EQ(OK, handles[i].Init(base::StringPrintf(
1229 "Take 2: %d", i), 1227 "Take 2: %d", i),
1230 params_, 1228 params_,
1231 kDefaultPriority, 1229 DEFAULT_PRIORITY,
1232 callback.callback(), 1230 callback.callback(),
1233 pool_.get(), 1231 pool_.get(),
1234 BoundNetLog())); 1232 BoundNetLog()));
1235 } 1233 }
1236 1234
1237 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count()); 1235 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count());
1238 EXPECT_EQ(0, pool_->IdleSocketCount()); 1236 EXPECT_EQ(0, pool_->IdleSocketCount());
1239 EXPECT_FALSE(pool_->IsStalled()); 1237 EXPECT_FALSE(pool_->IsStalled());
1240 1238
1241 // Now we will hit the socket limit. 1239 // Now we will hit the socket limit.
1242 EXPECT_EQ(ERR_IO_PENDING, stalled_handle.Init("foo", 1240 EXPECT_EQ(ERR_IO_PENDING, stalled_handle.Init("foo",
1243 params_, 1241 params_,
1244 kDefaultPriority, 1242 DEFAULT_PRIORITY,
1245 callback.callback(), 1243 callback.callback(),
1246 pool_.get(), 1244 pool_.get(),
1247 BoundNetLog())); 1245 BoundNetLog()));
1248 EXPECT_TRUE(pool_->IsStalled()); 1246 EXPECT_TRUE(pool_->IsStalled());
1249 1247
1250 // Dropping out of scope will close all handles and return them to idle. 1248 // Dropping out of scope will close all handles and return them to idle.
1251 } 1249 }
1252 1250
1253 // But if we wait for it, the released idle sockets will be closed in 1251 // But if we wait for it, the released idle sockets will be closed in
1254 // preference of the waiting request. 1252 // preference of the waiting request.
1255 EXPECT_EQ(OK, callback.WaitForResult()); 1253 EXPECT_EQ(OK, callback.WaitForResult());
1256 1254
1257 EXPECT_EQ(kDefaultMaxSockets + 1, client_socket_factory_.allocation_count()); 1255 EXPECT_EQ(kDefaultMaxSockets + 1, client_socket_factory_.allocation_count());
1258 EXPECT_EQ(3, pool_->IdleSocketCount()); 1256 EXPECT_EQ(3, pool_->IdleSocketCount());
1259 } 1257 }
1260 1258
1261 // Regression test for http://crbug.com/40952. 1259 // Regression test for http://crbug.com/40952.
1262 TEST_F(ClientSocketPoolBaseTest, CloseIdleSocketAtSocketLimitDeleteGroup) { 1260 TEST_F(ClientSocketPoolBaseTest, CloseIdleSocketAtSocketLimitDeleteGroup) {
1263 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1261 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1264 pool_->EnableConnectBackupJobs(); 1262 pool_->EnableConnectBackupJobs();
1265 connect_job_factory_->set_job_type(TestConnectJob::kMockJob); 1263 connect_job_factory_->set_job_type(TestConnectJob::kMockJob);
1266 1264
1267 for (int i = 0; i < kDefaultMaxSockets; ++i) { 1265 for (int i = 0; i < kDefaultMaxSockets; ++i) {
1268 ClientSocketHandle handle; 1266 ClientSocketHandle handle;
1269 TestCompletionCallback callback; 1267 TestCompletionCallback callback;
1270 EXPECT_EQ(OK, handle.Init(base::IntToString(i), 1268 EXPECT_EQ(OK, handle.Init(base::IntToString(i),
1271 params_, 1269 params_,
1272 kDefaultPriority, 1270 DEFAULT_PRIORITY,
1273 callback.callback(), 1271 callback.callback(),
1274 pool_.get(), 1272 pool_.get(),
1275 BoundNetLog())); 1273 BoundNetLog()));
1276 } 1274 }
1277 1275
1278 // Flush all the DoReleaseSocket tasks. 1276 // Flush all the DoReleaseSocket tasks.
1279 base::MessageLoop::current()->RunUntilIdle(); 1277 base::MessageLoop::current()->RunUntilIdle();
1280 1278
1281 // Stall a group. Set a pending job so it'll trigger a backup job if we don't 1279 // Stall a group. Set a pending job so it'll trigger a backup job if we don't
1282 // reuse a socket. 1280 // reuse a socket.
1283 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1281 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1284 ClientSocketHandle handle; 1282 ClientSocketHandle handle;
1285 TestCompletionCallback callback; 1283 TestCompletionCallback callback;
1286 1284
1287 // "0" is special here, since it should be the first entry in the sorted map, 1285 // "0" is special here, since it should be the first entry in the sorted map,
1288 // which is the one which we would close an idle socket for. We shouldn't 1286 // which is the one which we would close an idle socket for. We shouldn't
1289 // close an idle socket though, since we should reuse the idle socket. 1287 // close an idle socket though, since we should reuse the idle socket.
1290 EXPECT_EQ(OK, handle.Init("0", 1288 EXPECT_EQ(OK, handle.Init("0",
1291 params_, 1289 params_,
1292 kDefaultPriority, 1290 DEFAULT_PRIORITY,
1293 callback.callback(), 1291 callback.callback(),
1294 pool_.get(), 1292 pool_.get(),
1295 BoundNetLog())); 1293 BoundNetLog()));
1296 1294
1297 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count()); 1295 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count());
1298 EXPECT_EQ(kDefaultMaxSockets - 1, pool_->IdleSocketCount()); 1296 EXPECT_EQ(kDefaultMaxSockets - 1, pool_->IdleSocketCount());
1299 } 1297 }
1300 1298
1301 TEST_F(ClientSocketPoolBaseTest, PendingRequests) { 1299 TEST_F(ClientSocketPoolBaseTest, PendingRequests) {
1302 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1300 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1303 1301
1304 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1302 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1305 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1303 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1306 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", IDLE)); 1304 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", IDLE));
1307 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST)); 1305 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST));
1308 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", MEDIUM)); 1306 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", MEDIUM));
1309 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", HIGHEST)); 1307 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", HIGHEST));
1310 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOW)); 1308 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOW));
1311 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST)); 1309 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST));
1312 1310
1313 ReleaseAllConnections(ClientSocketPoolTest::KEEP_ALIVE); 1311 ReleaseAllConnections(ClientSocketPoolTest::KEEP_ALIVE);
1314 1312
1315 EXPECT_EQ(kDefaultMaxSocketsPerGroup, 1313 EXPECT_EQ(kDefaultMaxSocketsPerGroup,
(...skipping 10 matching lines...) Expand all
1326 EXPECT_EQ(5, GetOrderOfRequest(7)); 1324 EXPECT_EQ(5, GetOrderOfRequest(7));
1327 EXPECT_EQ(7, GetOrderOfRequest(8)); 1325 EXPECT_EQ(7, GetOrderOfRequest(8));
1328 1326
1329 // Make sure we test order of all requests made. 1327 // Make sure we test order of all requests made.
1330 EXPECT_EQ(ClientSocketPoolTest::kIndexOutOfBounds, GetOrderOfRequest(9)); 1328 EXPECT_EQ(ClientSocketPoolTest::kIndexOutOfBounds, GetOrderOfRequest(9));
1331 } 1329 }
1332 1330
1333 TEST_F(ClientSocketPoolBaseTest, PendingRequests_NoKeepAlive) { 1331 TEST_F(ClientSocketPoolBaseTest, PendingRequests_NoKeepAlive) {
1334 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1332 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1335 1333
1336 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1334 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1337 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1335 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1338 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST)); 1336 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST));
1339 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", MEDIUM)); 1337 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", MEDIUM));
1340 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", HIGHEST)); 1338 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", HIGHEST));
1341 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOW)); 1339 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOW));
1342 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST)); 1340 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST));
1343 1341
1344 ReleaseAllConnections(ClientSocketPoolTest::NO_KEEP_ALIVE); 1342 ReleaseAllConnections(ClientSocketPoolTest::NO_KEEP_ALIVE);
1345 1343
1346 for (size_t i = kDefaultMaxSocketsPerGroup; i < requests_size(); ++i) 1344 for (size_t i = kDefaultMaxSocketsPerGroup; i < requests_size(); ++i)
1347 EXPECT_EQ(OK, request(i)->WaitForResult()); 1345 EXPECT_EQ(OK, request(i)->WaitForResult());
1348 1346
1349 EXPECT_EQ(static_cast<int>(requests_size()), 1347 EXPECT_EQ(static_cast<int>(requests_size()),
1350 client_socket_factory_.allocation_count()); 1348 client_socket_factory_.allocation_count());
1351 EXPECT_EQ(requests_size() - kDefaultMaxSocketsPerGroup, 1349 EXPECT_EQ(requests_size() - kDefaultMaxSocketsPerGroup,
1352 completion_count()); 1350 completion_count());
1353 } 1351 }
1354 1352
1355 // This test will start up a RequestSocket() and then immediately Cancel() it. 1353 // This test will start up a RequestSocket() and then immediately Cancel() it.
1356 // The pending connect job will be cancelled and should not call back into 1354 // The pending connect job will be cancelled and should not call back into
1357 // ClientSocketPoolBase. 1355 // ClientSocketPoolBase.
1358 TEST_F(ClientSocketPoolBaseTest, CancelRequestClearGroup) { 1356 TEST_F(ClientSocketPoolBaseTest, CancelRequestClearGroup) {
1359 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1357 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1360 1358
1361 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1359 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1362 ClientSocketHandle handle; 1360 ClientSocketHandle handle;
1363 TestCompletionCallback callback; 1361 TestCompletionCallback callback;
1364 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 1362 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
1365 params_, 1363 params_,
1366 kDefaultPriority, 1364 DEFAULT_PRIORITY,
1367 callback.callback(), 1365 callback.callback(),
1368 pool_.get(), 1366 pool_.get(),
1369 BoundNetLog())); 1367 BoundNetLog()));
1370 handle.Reset(); 1368 handle.Reset();
1371 } 1369 }
1372 1370
1373 TEST_F(ClientSocketPoolBaseTest, ConnectCancelConnect) { 1371 TEST_F(ClientSocketPoolBaseTest, ConnectCancelConnect) {
1374 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1372 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1375 1373
1376 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1374 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1377 ClientSocketHandle handle; 1375 ClientSocketHandle handle;
1378 TestCompletionCallback callback; 1376 TestCompletionCallback callback;
1379 1377
1380 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 1378 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
1381 params_, 1379 params_,
1382 kDefaultPriority, 1380 DEFAULT_PRIORITY,
1383 callback.callback(), 1381 callback.callback(),
1384 pool_.get(), 1382 pool_.get(),
1385 BoundNetLog())); 1383 BoundNetLog()));
1386 1384
1387 handle.Reset(); 1385 handle.Reset();
1388 1386
1389 TestCompletionCallback callback2; 1387 TestCompletionCallback callback2;
1390 EXPECT_EQ(ERR_IO_PENDING, 1388 EXPECT_EQ(ERR_IO_PENDING,
1391 handle.Init("a", 1389 handle.Init("a",
1392 params_, 1390 params_,
1393 kDefaultPriority, 1391 DEFAULT_PRIORITY,
1394 callback2.callback(), 1392 callback2.callback(),
1395 pool_.get(), 1393 pool_.get(),
1396 BoundNetLog())); 1394 BoundNetLog()));
1397 1395
1398 EXPECT_EQ(OK, callback2.WaitForResult()); 1396 EXPECT_EQ(OK, callback2.WaitForResult());
1399 EXPECT_FALSE(callback.have_result()); 1397 EXPECT_FALSE(callback.have_result());
1400 1398
1401 handle.Reset(); 1399 handle.Reset();
1402 } 1400 }
1403 1401
1404 TEST_F(ClientSocketPoolBaseTest, CancelRequest) { 1402 TEST_F(ClientSocketPoolBaseTest, CancelRequest) {
1405 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1403 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1406 1404
1407 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1405 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1408 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1406 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1409 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST)); 1407 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST));
1410 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", MEDIUM)); 1408 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", MEDIUM));
1411 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", HIGHEST)); 1409 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", HIGHEST));
1412 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOW)); 1410 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOW));
1413 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST)); 1411 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", LOWEST));
1414 1412
1415 // Cancel a request. 1413 // Cancel a request.
1416 size_t index_to_cancel = kDefaultMaxSocketsPerGroup + 2; 1414 size_t index_to_cancel = kDefaultMaxSocketsPerGroup + 2;
1417 EXPECT_FALSE((*requests())[index_to_cancel]->handle()->is_initialized()); 1415 EXPECT_FALSE((*requests())[index_to_cancel]->handle()->is_initialized());
1418 (*requests())[index_to_cancel]->handle()->Reset(); 1416 (*requests())[index_to_cancel]->handle()->Reset();
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after
1471 { 1469 {
1472 // TODO: Resolve conflicting intentions of stopping recursion with the 1470 // TODO: Resolve conflicting intentions of stopping recursion with the
1473 // |!within_callback_| test (above) and the call to |RunUntilIdle()| 1471 // |!within_callback_| test (above) and the call to |RunUntilIdle()|
1474 // below. http://crbug.com/114130. 1472 // below. http://crbug.com/114130.
1475 base::MessageLoop::ScopedNestableTaskAllower allow( 1473 base::MessageLoop::ScopedNestableTaskAllower allow(
1476 base::MessageLoop::current()); 1474 base::MessageLoop::current());
1477 base::MessageLoop::current()->RunUntilIdle(); 1475 base::MessageLoop::current()->RunUntilIdle();
1478 } 1476 }
1479 within_callback_ = true; 1477 within_callback_ = true;
1480 TestCompletionCallback next_job_callback; 1478 TestCompletionCallback next_job_callback;
1481 scoped_refptr<TestSocketParams> params(new TestSocketParams()); 1479 scoped_refptr<TestSocketParams> params(
1480 new TestSocketParams(RESPECT_LIMITS));
1482 int rv = handle_->Init("a", 1481 int rv = handle_->Init("a",
1483 params, 1482 params,
1484 kDefaultPriority, 1483 DEFAULT_PRIORITY,
1485 next_job_callback.callback(), 1484 next_job_callback.callback(),
1486 pool_, 1485 pool_,
1487 BoundNetLog()); 1486 BoundNetLog());
1488 switch (next_job_type_) { 1487 switch (next_job_type_) {
1489 case TestConnectJob::kMockJob: 1488 case TestConnectJob::kMockJob:
1490 EXPECT_EQ(OK, rv); 1489 EXPECT_EQ(OK, rv);
1491 break; 1490 break;
1492 case TestConnectJob::kMockPendingJob: 1491 case TestConnectJob::kMockPendingJob:
1493 EXPECT_EQ(ERR_IO_PENDING, rv); 1492 EXPECT_EQ(ERR_IO_PENDING, rv);
1494 1493
(...skipping 28 matching lines...) Expand all
1523 TEST_F(ClientSocketPoolBaseTest, RequestPendingJobTwice) { 1522 TEST_F(ClientSocketPoolBaseTest, RequestPendingJobTwice) {
1524 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1523 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1525 1524
1526 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1525 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1527 ClientSocketHandle handle; 1526 ClientSocketHandle handle;
1528 RequestSocketCallback callback( 1527 RequestSocketCallback callback(
1529 &handle, pool_.get(), connect_job_factory_, 1528 &handle, pool_.get(), connect_job_factory_,
1530 TestConnectJob::kMockPendingJob); 1529 TestConnectJob::kMockPendingJob);
1531 int rv = handle.Init("a", 1530 int rv = handle.Init("a",
1532 params_, 1531 params_,
1533 kDefaultPriority, 1532 DEFAULT_PRIORITY,
1534 callback.callback(), 1533 callback.callback(),
1535 pool_.get(), 1534 pool_.get(),
1536 BoundNetLog()); 1535 BoundNetLog());
1537 ASSERT_EQ(ERR_IO_PENDING, rv); 1536 ASSERT_EQ(ERR_IO_PENDING, rv);
1538 1537
1539 EXPECT_EQ(OK, callback.WaitForResult()); 1538 EXPECT_EQ(OK, callback.WaitForResult());
1540 } 1539 }
1541 1540
1542 TEST_F(ClientSocketPoolBaseTest, RequestPendingJobThenSynchronous) { 1541 TEST_F(ClientSocketPoolBaseTest, RequestPendingJobThenSynchronous) {
1543 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1542 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1544 1543
1545 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1544 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1546 ClientSocketHandle handle; 1545 ClientSocketHandle handle;
1547 RequestSocketCallback callback( 1546 RequestSocketCallback callback(
1548 &handle, pool_.get(), connect_job_factory_, TestConnectJob::kMockJob); 1547 &handle, pool_.get(), connect_job_factory_, TestConnectJob::kMockJob);
1549 int rv = handle.Init("a", 1548 int rv = handle.Init("a",
1550 params_, 1549 params_,
1551 kDefaultPriority, 1550 DEFAULT_PRIORITY,
1552 callback.callback(), 1551 callback.callback(),
1553 pool_.get(), 1552 pool_.get(),
1554 BoundNetLog()); 1553 BoundNetLog());
1555 ASSERT_EQ(ERR_IO_PENDING, rv); 1554 ASSERT_EQ(ERR_IO_PENDING, rv);
1556 1555
1557 EXPECT_EQ(OK, callback.WaitForResult()); 1556 EXPECT_EQ(OK, callback.WaitForResult());
1558 } 1557 }
1559 1558
1560 // Make sure that pending requests get serviced after active requests get 1559 // Make sure that pending requests get serviced after active requests get
1561 // cancelled. 1560 // cancelled.
1562 TEST_F(ClientSocketPoolBaseTest, CancelActiveRequestWithPendingRequests) { 1561 TEST_F(ClientSocketPoolBaseTest, CancelActiveRequestWithPendingRequests) {
1563 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1562 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1564 1563
1565 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1564 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1566 1565
1567 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 1566 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
1568 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 1567 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
1569 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 1568 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
1570 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 1569 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
1571 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 1570 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
1572 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 1571 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
1573 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 1572 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
1574 1573
1575 // Now, kDefaultMaxSocketsPerGroup requests should be active. 1574 // Now, kDefaultMaxSocketsPerGroup requests should be active.
1576 // Let's cancel them. 1575 // Let's cancel them.
1577 for (int i = 0; i < kDefaultMaxSocketsPerGroup; ++i) { 1576 for (int i = 0; i < kDefaultMaxSocketsPerGroup; ++i) {
1578 ASSERT_FALSE(request(i)->handle()->is_initialized()); 1577 ASSERT_FALSE(request(i)->handle()->is_initialized());
1579 request(i)->handle()->Reset(); 1578 request(i)->handle()->Reset();
1580 } 1579 }
1581 1580
1582 // Let's wait for the rest to complete now. 1581 // Let's wait for the rest to complete now.
1583 for (size_t i = kDefaultMaxSocketsPerGroup; i < requests_size(); ++i) { 1582 for (size_t i = kDefaultMaxSocketsPerGroup; i < requests_size(); ++i) {
(...skipping 10 matching lines...) Expand all
1594 const size_t kMaxSockets = 5; 1593 const size_t kMaxSockets = 5;
1595 CreatePool(kMaxSockets, kDefaultMaxSocketsPerGroup); 1594 CreatePool(kMaxSockets, kDefaultMaxSocketsPerGroup);
1596 1595
1597 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingFailingJob); 1596 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingFailingJob);
1598 1597
1599 const size_t kNumberOfRequests = 2 * kDefaultMaxSocketsPerGroup + 1; 1598 const size_t kNumberOfRequests = 2 * kDefaultMaxSocketsPerGroup + 1;
1600 ASSERT_LE(kNumberOfRequests, kMaxSockets); // Otherwise the test will hang. 1599 ASSERT_LE(kNumberOfRequests, kMaxSockets); // Otherwise the test will hang.
1601 1600
1602 // Queue up all the requests 1601 // Queue up all the requests
1603 for (size_t i = 0; i < kNumberOfRequests; ++i) 1602 for (size_t i = 0; i < kNumberOfRequests; ++i)
1604 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 1603 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
1605 1604
1606 for (size_t i = 0; i < kNumberOfRequests; ++i) 1605 for (size_t i = 0; i < kNumberOfRequests; ++i)
1607 EXPECT_EQ(ERR_CONNECTION_FAILED, request(i)->WaitForResult()); 1606 EXPECT_EQ(ERR_CONNECTION_FAILED, request(i)->WaitForResult());
1608 } 1607 }
1609 1608
1610 TEST_F(ClientSocketPoolBaseTest, CancelActiveRequestThenRequestSocket) { 1609 TEST_F(ClientSocketPoolBaseTest, CancelActiveRequestThenRequestSocket) {
1611 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1610 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1612 1611
1613 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1612 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1614 1613
1615 ClientSocketHandle handle; 1614 ClientSocketHandle handle;
1616 TestCompletionCallback callback; 1615 TestCompletionCallback callback;
1617 int rv = handle.Init("a", 1616 int rv = handle.Init("a",
1618 params_, 1617 params_,
1619 kDefaultPriority, 1618 DEFAULT_PRIORITY,
1620 callback.callback(), 1619 callback.callback(),
1621 pool_.get(), 1620 pool_.get(),
1622 BoundNetLog()); 1621 BoundNetLog());
1623 EXPECT_EQ(ERR_IO_PENDING, rv); 1622 EXPECT_EQ(ERR_IO_PENDING, rv);
1624 1623
1625 // Cancel the active request. 1624 // Cancel the active request.
1626 handle.Reset(); 1625 handle.Reset();
1627 1626
1628 rv = handle.Init("a", 1627 rv = handle.Init("a",
1629 params_, 1628 params_,
1630 kDefaultPriority, 1629 DEFAULT_PRIORITY,
1631 callback.callback(), 1630 callback.callback(),
1632 pool_.get(), 1631 pool_.get(),
1633 BoundNetLog()); 1632 BoundNetLog());
1634 EXPECT_EQ(ERR_IO_PENDING, rv); 1633 EXPECT_EQ(ERR_IO_PENDING, rv);
1635 EXPECT_EQ(OK, callback.WaitForResult()); 1634 EXPECT_EQ(OK, callback.WaitForResult());
1636 1635
1637 EXPECT_FALSE(handle.is_reused()); 1636 EXPECT_FALSE(handle.is_reused());
1638 TestLoadTimingInfoConnectedNotReused(handle); 1637 TestLoadTimingInfoConnectedNotReused(handle);
1639 EXPECT_EQ(2, client_socket_factory_.allocation_count()); 1638 EXPECT_EQ(2, client_socket_factory_.allocation_count());
1640 } 1639 }
1641 1640
1642 // Regression test for http://crbug.com/17985. 1641 // Regression test for http://crbug.com/17985.
1643 TEST_F(ClientSocketPoolBaseTest, GroupWithPendingRequestsIsNotEmpty) { 1642 TEST_F(ClientSocketPoolBaseTest, GroupWithPendingRequestsIsNotEmpty) {
1644 const int kMaxSockets = 3; 1643 const int kMaxSockets = 3;
1645 const int kMaxSocketsPerGroup = 2; 1644 const int kMaxSocketsPerGroup = 2;
1646 CreatePool(kMaxSockets, kMaxSocketsPerGroup); 1645 CreatePool(kMaxSockets, kMaxSocketsPerGroup);
1647 1646
1648 const RequestPriority kHighPriority = HIGHEST; 1647 const RequestPriority kHighPriority = HIGHEST;
1649 1648
1650 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1649 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1651 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 1650 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
1652 1651
1653 // This is going to be a pending request in an otherwise empty group. 1652 // This is going to be a pending request in an otherwise empty group.
1654 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 1653 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
1655 1654
1656 // Reach the maximum socket limit. 1655 // Reach the maximum socket limit.
1657 EXPECT_EQ(OK, StartRequest("b", kDefaultPriority)); 1656 EXPECT_EQ(OK, StartRequest("b", DEFAULT_PRIORITY));
1658 1657
1659 // Create a stalled group with high priorities. 1658 // Create a stalled group with high priorities.
1660 EXPECT_EQ(ERR_IO_PENDING, StartRequest("c", kHighPriority)); 1659 EXPECT_EQ(ERR_IO_PENDING, StartRequest("c", kHighPriority));
1661 EXPECT_EQ(ERR_IO_PENDING, StartRequest("c", kHighPriority)); 1660 EXPECT_EQ(ERR_IO_PENDING, StartRequest("c", kHighPriority));
1662 1661
1663 // Release the first two sockets from "a". Because this is a keepalive, 1662 // Release the first two sockets from "a". Because this is a keepalive,
1664 // the first release will unblock the pending request for "a". The 1663 // the first release will unblock the pending request for "a". The
1665 // second release will unblock a request for "c", becaue it is the next 1664 // second release will unblock a request for "c", becaue it is the next
1666 // high priority socket. 1665 // high priority socket.
1667 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE)); 1666 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::KEEP_ALIVE));
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after
1725 ClientSocketHandle handle; 1724 ClientSocketHandle handle;
1726 TestCompletionCallback callback; 1725 TestCompletionCallback callback;
1727 CapturingBoundNetLog log; 1726 CapturingBoundNetLog log;
1728 // Set the additional error state members to ensure that they get cleared. 1727 // Set the additional error state members to ensure that they get cleared.
1729 handle.set_is_ssl_error(true); 1728 handle.set_is_ssl_error(true);
1730 HttpResponseInfo info; 1729 HttpResponseInfo info;
1731 info.headers = new HttpResponseHeaders(std::string()); 1730 info.headers = new HttpResponseHeaders(std::string());
1732 handle.set_ssl_error_response_info(info); 1731 handle.set_ssl_error_response_info(info);
1733 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 1732 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
1734 params_, 1733 params_,
1735 kDefaultPriority, 1734 DEFAULT_PRIORITY,
1736 callback.callback(), 1735 callback.callback(),
1737 pool_.get(), 1736 pool_.get(),
1738 log.bound())); 1737 log.bound()));
1739 EXPECT_EQ(LOAD_STATE_CONNECTING, pool_->GetLoadState("a", &handle)); 1738 EXPECT_EQ(LOAD_STATE_CONNECTING, pool_->GetLoadState("a", &handle));
1740 EXPECT_EQ(ERR_CONNECTION_FAILED, callback.WaitForResult()); 1739 EXPECT_EQ(ERR_CONNECTION_FAILED, callback.WaitForResult());
1741 EXPECT_FALSE(handle.is_ssl_error()); 1740 EXPECT_FALSE(handle.is_ssl_error());
1742 EXPECT_TRUE(handle.ssl_error_response_info().headers.get() == NULL); 1741 EXPECT_TRUE(handle.ssl_error_response_info().headers.get() == NULL);
1743 1742
1744 CapturingNetLog::CapturedEntryList entries; 1743 CapturingNetLog::CapturedEntryList entries;
1745 log.GetEntries(&entries); 1744 log.GetEntries(&entries);
(...skipping 15 matching lines...) Expand all
1761 1760
1762 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1761 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1763 ClientSocketHandle handle; 1762 ClientSocketHandle handle;
1764 TestCompletionCallback callback; 1763 TestCompletionCallback callback;
1765 ClientSocketHandle handle2; 1764 ClientSocketHandle handle2;
1766 TestCompletionCallback callback2; 1765 TestCompletionCallback callback2;
1767 1766
1768 EXPECT_EQ(ERR_IO_PENDING, 1767 EXPECT_EQ(ERR_IO_PENDING,
1769 handle.Init("a", 1768 handle.Init("a",
1770 params_, 1769 params_,
1771 kDefaultPriority, 1770 DEFAULT_PRIORITY,
1772 callback.callback(), 1771 callback.callback(),
1773 pool_.get(), 1772 pool_.get(),
1774 BoundNetLog())); 1773 BoundNetLog()));
1775 CapturingBoundNetLog log2; 1774 CapturingBoundNetLog log2;
1776 EXPECT_EQ(ERR_IO_PENDING, 1775 EXPECT_EQ(ERR_IO_PENDING,
1777 handle2.Init("a", 1776 handle2.Init("a",
1778 params_, 1777 params_,
1779 kDefaultPriority, 1778 DEFAULT_PRIORITY,
1780 callback2.callback(), 1779 callback2.callback(),
1781 pool_.get(), 1780 pool_.get(),
1782 BoundNetLog())); 1781 BoundNetLog()));
1783 1782
1784 handle.Reset(); 1783 handle.Reset();
1785 1784
1786 1785
1787 // At this point, request 2 is just waiting for the connect job to finish. 1786 // At this point, request 2 is just waiting for the connect job to finish.
1788 1787
1789 EXPECT_EQ(OK, callback2.WaitForResult()); 1788 EXPECT_EQ(OK, callback2.WaitForResult());
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
1821 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1820 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1822 1821
1823 // Start job 1 (async OK) 1822 // Start job 1 (async OK)
1824 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 1823 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
1825 1824
1826 std::vector<TestSocketRequest*> request_order; 1825 std::vector<TestSocketRequest*> request_order;
1827 size_t completion_count; // unused 1826 size_t completion_count; // unused
1828 TestSocketRequest req1(&request_order, &completion_count); 1827 TestSocketRequest req1(&request_order, &completion_count);
1829 int rv = req1.handle()->Init("a", 1828 int rv = req1.handle()->Init("a",
1830 params_, 1829 params_,
1831 kDefaultPriority, 1830 DEFAULT_PRIORITY,
1832 req1.callback(), pool_.get(), 1831 req1.callback(), pool_.get(),
1833 BoundNetLog()); 1832 BoundNetLog());
1834 EXPECT_EQ(ERR_IO_PENDING, rv); 1833 EXPECT_EQ(ERR_IO_PENDING, rv);
1835 EXPECT_EQ(OK, req1.WaitForResult()); 1834 EXPECT_EQ(OK, req1.WaitForResult());
1836 1835
1837 // Job 1 finished OK. Start job 2 (also async OK). Request 3 is pending 1836 // Job 1 finished OK. Start job 2 (also async OK). Request 3 is pending
1838 // without a job. 1837 // without a job.
1839 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 1838 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
1840 1839
1841 TestSocketRequest req2(&request_order, &completion_count); 1840 TestSocketRequest req2(&request_order, &completion_count);
1842 rv = req2.handle()->Init("a", 1841 rv = req2.handle()->Init("a",
1843 params_, 1842 params_,
1844 kDefaultPriority, 1843 DEFAULT_PRIORITY,
1845 req2.callback(), 1844 req2.callback(),
1846 pool_.get(), 1845 pool_.get(),
1847 BoundNetLog()); 1846 BoundNetLog());
1848 EXPECT_EQ(ERR_IO_PENDING, rv); 1847 EXPECT_EQ(ERR_IO_PENDING, rv);
1849 TestSocketRequest req3(&request_order, &completion_count); 1848 TestSocketRequest req3(&request_order, &completion_count);
1850 rv = req3.handle()->Init("a", 1849 rv = req3.handle()->Init("a",
1851 params_, 1850 params_,
1852 kDefaultPriority, 1851 DEFAULT_PRIORITY,
1853 req3.callback(), 1852 req3.callback(),
1854 pool_.get(), 1853 pool_.get(),
1855 BoundNetLog()); 1854 BoundNetLog());
1856 EXPECT_EQ(ERR_IO_PENDING, rv); 1855 EXPECT_EQ(ERR_IO_PENDING, rv);
1857 1856
1858 // Both Requests 2 and 3 are pending. We release socket 1 which should 1857 // Both Requests 2 and 3 are pending. We release socket 1 which should
1859 // service request 2. Request 3 should still be waiting. 1858 // service request 2. Request 3 should still be waiting.
1860 req1.handle()->Reset(); 1859 req1.handle()->Reset();
1861 // Run the released socket wakeups. 1860 // Run the released socket wakeups.
1862 base::MessageLoop::current()->RunUntilIdle(); 1861 base::MessageLoop::current()->RunUntilIdle();
(...skipping 18 matching lines...) Expand all
1881 TEST_F(ClientSocketPoolBaseTest, PendingJobCompletionOrder) { 1880 TEST_F(ClientSocketPoolBaseTest, PendingJobCompletionOrder) {
1882 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1881 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1883 // First two jobs are async. 1882 // First two jobs are async.
1884 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingFailingJob); 1883 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingFailingJob);
1885 1884
1886 std::vector<TestSocketRequest*> request_order; 1885 std::vector<TestSocketRequest*> request_order;
1887 size_t completion_count; // unused 1886 size_t completion_count; // unused
1888 TestSocketRequest req1(&request_order, &completion_count); 1887 TestSocketRequest req1(&request_order, &completion_count);
1889 int rv = req1.handle()->Init("a", 1888 int rv = req1.handle()->Init("a",
1890 params_, 1889 params_,
1891 kDefaultPriority, 1890 DEFAULT_PRIORITY,
1892 req1.callback(), 1891 req1.callback(),
1893 pool_.get(), 1892 pool_.get(),
1894 BoundNetLog()); 1893 BoundNetLog());
1895 EXPECT_EQ(ERR_IO_PENDING, rv); 1894 EXPECT_EQ(ERR_IO_PENDING, rv);
1896 1895
1897 TestSocketRequest req2(&request_order, &completion_count); 1896 TestSocketRequest req2(&request_order, &completion_count);
1898 rv = req2.handle()->Init("a", 1897 rv = req2.handle()->Init("a",
1899 params_, 1898 params_,
1900 kDefaultPriority, 1899 DEFAULT_PRIORITY,
1901 req2.callback(), 1900 req2.callback(),
1902 pool_.get(), 1901 pool_.get(),
1903 BoundNetLog()); 1902 BoundNetLog());
1904 EXPECT_EQ(ERR_IO_PENDING, rv); 1903 EXPECT_EQ(ERR_IO_PENDING, rv);
1905 1904
1906 // The pending job is sync. 1905 // The pending job is sync.
1907 connect_job_factory_->set_job_type(TestConnectJob::kMockJob); 1906 connect_job_factory_->set_job_type(TestConnectJob::kMockJob);
1908 1907
1909 TestSocketRequest req3(&request_order, &completion_count); 1908 TestSocketRequest req3(&request_order, &completion_count);
1910 rv = req3.handle()->Init("a", 1909 rv = req3.handle()->Init("a",
1911 params_, 1910 params_,
1912 kDefaultPriority, 1911 DEFAULT_PRIORITY,
1913 req3.callback(), 1912 req3.callback(),
1914 pool_.get(), 1913 pool_.get(),
1915 BoundNetLog()); 1914 BoundNetLog());
1916 EXPECT_EQ(ERR_IO_PENDING, rv); 1915 EXPECT_EQ(ERR_IO_PENDING, rv);
1917 1916
1918 EXPECT_EQ(ERR_CONNECTION_FAILED, req1.WaitForResult()); 1917 EXPECT_EQ(ERR_CONNECTION_FAILED, req1.WaitForResult());
1919 EXPECT_EQ(OK, req2.WaitForResult()); 1918 EXPECT_EQ(OK, req2.WaitForResult());
1920 EXPECT_EQ(ERR_CONNECTION_FAILED, req3.WaitForResult()); 1919 EXPECT_EQ(ERR_CONNECTION_FAILED, req3.WaitForResult());
1921 1920
1922 ASSERT_EQ(3U, request_order.size()); 1921 ASSERT_EQ(3U, request_order.size());
1923 EXPECT_EQ(&req1, request_order[0]); 1922 EXPECT_EQ(&req1, request_order[0]);
1924 EXPECT_EQ(&req2, request_order[1]); 1923 EXPECT_EQ(&req2, request_order[1]);
1925 EXPECT_EQ(&req3, request_order[2]); 1924 EXPECT_EQ(&req3, request_order[2]);
1926 } 1925 }
1927 1926
1928 // Test GetLoadState in the case there's only one socket request. 1927 // Test GetLoadState in the case there's only one socket request.
1929 TEST_F(ClientSocketPoolBaseTest, LoadStateOneRequest) { 1928 TEST_F(ClientSocketPoolBaseTest, LoadStateOneRequest) {
1930 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 1929 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
1931 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 1930 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
1932 1931
1933 ClientSocketHandle handle; 1932 ClientSocketHandle handle;
1934 TestCompletionCallback callback; 1933 TestCompletionCallback callback;
1935 int rv = handle.Init("a", 1934 int rv = handle.Init("a",
1936 params_, 1935 params_,
1937 kDefaultPriority, 1936 DEFAULT_PRIORITY,
1938 callback.callback(), 1937 callback.callback(),
1939 pool_.get(), 1938 pool_.get(),
1940 BoundNetLog()); 1939 BoundNetLog());
1941 EXPECT_EQ(ERR_IO_PENDING, rv); 1940 EXPECT_EQ(ERR_IO_PENDING, rv);
1942 EXPECT_EQ(LOAD_STATE_CONNECTING, handle.GetLoadState()); 1941 EXPECT_EQ(LOAD_STATE_CONNECTING, handle.GetLoadState());
1943 1942
1944 client_socket_factory_.SetJobLoadState(0, LOAD_STATE_SSL_HANDSHAKE); 1943 client_socket_factory_.SetJobLoadState(0, LOAD_STATE_SSL_HANDSHAKE);
1945 EXPECT_EQ(LOAD_STATE_SSL_HANDSHAKE, handle.GetLoadState()); 1944 EXPECT_EQ(LOAD_STATE_SSL_HANDSHAKE, handle.GetLoadState());
1946 1945
1947 // No point in completing the connection, since ClientSocketHandles only 1946 // No point in completing the connection, since ClientSocketHandles only
1948 // expect the LoadState to be checked while connecting. 1947 // expect the LoadState to be checked while connecting.
1949 } 1948 }
1950 1949
1951 // Test GetLoadState in the case there are two socket requests. 1950 // Test GetLoadState in the case there are two socket requests.
1952 TEST_F(ClientSocketPoolBaseTest, LoadStateTwoRequests) { 1951 TEST_F(ClientSocketPoolBaseTest, LoadStateTwoRequests) {
1953 CreatePool(2, 2); 1952 CreatePool(2, 2);
1954 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 1953 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
1955 1954
1956 ClientSocketHandle handle; 1955 ClientSocketHandle handle;
1957 TestCompletionCallback callback; 1956 TestCompletionCallback callback;
1958 int rv = handle.Init("a", 1957 int rv = handle.Init("a",
1959 params_, 1958 params_,
1960 kDefaultPriority, 1959 DEFAULT_PRIORITY,
1961 callback.callback(), 1960 callback.callback(),
1962 pool_.get(), 1961 pool_.get(),
1963 BoundNetLog()); 1962 BoundNetLog());
1964 EXPECT_EQ(ERR_IO_PENDING, rv); 1963 EXPECT_EQ(ERR_IO_PENDING, rv);
1965 1964
1966 ClientSocketHandle handle2; 1965 ClientSocketHandle handle2;
1967 TestCompletionCallback callback2; 1966 TestCompletionCallback callback2;
1968 rv = handle2.Init("a", 1967 rv = handle2.Init("a",
1969 params_, 1968 params_,
1970 kDefaultPriority, 1969 DEFAULT_PRIORITY,
1971 callback2.callback(), 1970 callback2.callback(),
1972 pool_.get(), 1971 pool_.get(),
1973 BoundNetLog()); 1972 BoundNetLog());
1974 EXPECT_EQ(ERR_IO_PENDING, rv); 1973 EXPECT_EQ(ERR_IO_PENDING, rv);
1975 1974
1976 // If the first Job is in an earlier state than the second, the state of 1975 // If the first Job is in an earlier state than the second, the state of
1977 // the second job should be used for both handles. 1976 // the second job should be used for both handles.
1978 client_socket_factory_.SetJobLoadState(0, LOAD_STATE_RESOLVING_HOST); 1977 client_socket_factory_.SetJobLoadState(0, LOAD_STATE_RESOLVING_HOST);
1979 EXPECT_EQ(LOAD_STATE_CONNECTING, handle.GetLoadState()); 1978 EXPECT_EQ(LOAD_STATE_CONNECTING, handle.GetLoadState());
1980 EXPECT_EQ(LOAD_STATE_CONNECTING, handle2.GetLoadState()); 1979 EXPECT_EQ(LOAD_STATE_CONNECTING, handle2.GetLoadState());
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after
2043 2042
2044 // Test GetLoadState in the case the per-pool limit is reached. 2043 // Test GetLoadState in the case the per-pool limit is reached.
2045 TEST_F(ClientSocketPoolBaseTest, LoadStatePoolLimit) { 2044 TEST_F(ClientSocketPoolBaseTest, LoadStatePoolLimit) {
2046 CreatePool(2, 2); 2045 CreatePool(2, 2);
2047 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 2046 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
2048 2047
2049 ClientSocketHandle handle; 2048 ClientSocketHandle handle;
2050 TestCompletionCallback callback; 2049 TestCompletionCallback callback;
2051 int rv = handle.Init("a", 2050 int rv = handle.Init("a",
2052 params_, 2051 params_,
2053 kDefaultPriority, 2052 DEFAULT_PRIORITY,
2054 callback.callback(), 2053 callback.callback(),
2055 pool_.get(), 2054 pool_.get(),
2056 BoundNetLog()); 2055 BoundNetLog());
2057 EXPECT_EQ(ERR_IO_PENDING, rv); 2056 EXPECT_EQ(ERR_IO_PENDING, rv);
2058 2057
2059 // Request for socket from another pool. 2058 // Request for socket from another pool.
2060 ClientSocketHandle handle2; 2059 ClientSocketHandle handle2;
2061 TestCompletionCallback callback2; 2060 TestCompletionCallback callback2;
2062 rv = handle2.Init("b", 2061 rv = handle2.Init("b",
2063 params_, 2062 params_,
2064 kDefaultPriority, 2063 DEFAULT_PRIORITY,
2065 callback2.callback(), 2064 callback2.callback(),
2066 pool_.get(), 2065 pool_.get(),
2067 BoundNetLog()); 2066 BoundNetLog());
2068 EXPECT_EQ(ERR_IO_PENDING, rv); 2067 EXPECT_EQ(ERR_IO_PENDING, rv);
2069 2068
2070 // Request another socket from the first pool. Request should stall at the 2069 // Request another socket from the first pool. Request should stall at the
2071 // socket pool limit. 2070 // socket pool limit.
2072 ClientSocketHandle handle3; 2071 ClientSocketHandle handle3;
2073 TestCompletionCallback callback3; 2072 TestCompletionCallback callback3;
2074 rv = handle3.Init("a", 2073 rv = handle3.Init("a",
2075 params_, 2074 params_,
2076 kDefaultPriority, 2075 DEFAULT_PRIORITY,
2077 callback2.callback(), 2076 callback2.callback(),
2078 pool_.get(), 2077 pool_.get(),
2079 BoundNetLog()); 2078 BoundNetLog());
2080 EXPECT_EQ(ERR_IO_PENDING, rv); 2079 EXPECT_EQ(ERR_IO_PENDING, rv);
2081 2080
2082 // The third handle should remain stalled as the other sockets in its group 2081 // The third handle should remain stalled as the other sockets in its group
2083 // goes through the connect process. 2082 // goes through the connect process.
2084 2083
2085 EXPECT_EQ(LOAD_STATE_CONNECTING, handle.GetLoadState()); 2084 EXPECT_EQ(LOAD_STATE_CONNECTING, handle.GetLoadState());
2086 EXPECT_EQ(LOAD_STATE_WAITING_FOR_STALLED_SOCKET_POOL, handle3.GetLoadState()); 2085 EXPECT_EQ(LOAD_STATE_WAITING_FOR_STALLED_SOCKET_POOL, handle3.GetLoadState());
(...skipping 13 matching lines...) Expand all
2100 EXPECT_EQ(LOAD_STATE_CONNECTING, handle3.GetLoadState()); 2099 EXPECT_EQ(LOAD_STATE_CONNECTING, handle3.GetLoadState());
2101 } 2100 }
2102 2101
2103 TEST_F(ClientSocketPoolBaseTest, Recoverable) { 2102 TEST_F(ClientSocketPoolBaseTest, Recoverable) {
2104 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2103 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2105 connect_job_factory_->set_job_type(TestConnectJob::kMockRecoverableJob); 2104 connect_job_factory_->set_job_type(TestConnectJob::kMockRecoverableJob);
2106 2105
2107 ClientSocketHandle handle; 2106 ClientSocketHandle handle;
2108 TestCompletionCallback callback; 2107 TestCompletionCallback callback;
2109 EXPECT_EQ(ERR_PROXY_AUTH_REQUESTED, 2108 EXPECT_EQ(ERR_PROXY_AUTH_REQUESTED,
2110 handle.Init("a", params_, kDefaultPriority, callback.callback(), 2109 handle.Init("a", params_, DEFAULT_PRIORITY, callback.callback(),
2111 pool_.get(), BoundNetLog())); 2110 pool_.get(), BoundNetLog()));
2112 EXPECT_TRUE(handle.is_initialized()); 2111 EXPECT_TRUE(handle.is_initialized());
2113 EXPECT_TRUE(handle.socket()); 2112 EXPECT_TRUE(handle.socket());
2114 } 2113 }
2115 2114
2116 TEST_F(ClientSocketPoolBaseTest, AsyncRecoverable) { 2115 TEST_F(ClientSocketPoolBaseTest, AsyncRecoverable) {
2117 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2116 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2118 2117
2119 connect_job_factory_->set_job_type( 2118 connect_job_factory_->set_job_type(
2120 TestConnectJob::kMockPendingRecoverableJob); 2119 TestConnectJob::kMockPendingRecoverableJob);
2121 ClientSocketHandle handle; 2120 ClientSocketHandle handle;
2122 TestCompletionCallback callback; 2121 TestCompletionCallback callback;
2123 EXPECT_EQ(ERR_IO_PENDING, 2122 EXPECT_EQ(ERR_IO_PENDING,
2124 handle.Init("a", 2123 handle.Init("a",
2125 params_, 2124 params_,
2126 kDefaultPriority, 2125 DEFAULT_PRIORITY,
2127 callback.callback(), 2126 callback.callback(),
2128 pool_.get(), 2127 pool_.get(),
2129 BoundNetLog())); 2128 BoundNetLog()));
2130 EXPECT_EQ(LOAD_STATE_CONNECTING, pool_->GetLoadState("a", &handle)); 2129 EXPECT_EQ(LOAD_STATE_CONNECTING, pool_->GetLoadState("a", &handle));
2131 EXPECT_EQ(ERR_PROXY_AUTH_REQUESTED, callback.WaitForResult()); 2130 EXPECT_EQ(ERR_PROXY_AUTH_REQUESTED, callback.WaitForResult());
2132 EXPECT_TRUE(handle.is_initialized()); 2131 EXPECT_TRUE(handle.is_initialized());
2133 EXPECT_TRUE(handle.socket()); 2132 EXPECT_TRUE(handle.socket());
2134 } 2133 }
2135 2134
2136 TEST_F(ClientSocketPoolBaseTest, AdditionalErrorStateSynchronous) { 2135 TEST_F(ClientSocketPoolBaseTest, AdditionalErrorStateSynchronous) {
2137 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2136 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2138 connect_job_factory_->set_job_type( 2137 connect_job_factory_->set_job_type(
2139 TestConnectJob::kMockAdditionalErrorStateJob); 2138 TestConnectJob::kMockAdditionalErrorStateJob);
2140 2139
2141 ClientSocketHandle handle; 2140 ClientSocketHandle handle;
2142 TestCompletionCallback callback; 2141 TestCompletionCallback callback;
2143 EXPECT_EQ(ERR_CONNECTION_FAILED, 2142 EXPECT_EQ(ERR_CONNECTION_FAILED,
2144 handle.Init("a", 2143 handle.Init("a",
2145 params_, 2144 params_,
2146 kDefaultPriority, 2145 DEFAULT_PRIORITY,
2147 callback.callback(), 2146 callback.callback(),
2148 pool_.get(), 2147 pool_.get(),
2149 BoundNetLog())); 2148 BoundNetLog()));
2150 EXPECT_FALSE(handle.is_initialized()); 2149 EXPECT_FALSE(handle.is_initialized());
2151 EXPECT_FALSE(handle.socket()); 2150 EXPECT_FALSE(handle.socket());
2152 EXPECT_TRUE(handle.is_ssl_error()); 2151 EXPECT_TRUE(handle.is_ssl_error());
2153 EXPECT_FALSE(handle.ssl_error_response_info().headers.get() == NULL); 2152 EXPECT_FALSE(handle.ssl_error_response_info().headers.get() == NULL);
2154 } 2153 }
2155 2154
2156 TEST_F(ClientSocketPoolBaseTest, AdditionalErrorStateAsynchronous) { 2155 TEST_F(ClientSocketPoolBaseTest, AdditionalErrorStateAsynchronous) {
2157 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2156 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2158 2157
2159 connect_job_factory_->set_job_type( 2158 connect_job_factory_->set_job_type(
2160 TestConnectJob::kMockPendingAdditionalErrorStateJob); 2159 TestConnectJob::kMockPendingAdditionalErrorStateJob);
2161 ClientSocketHandle handle; 2160 ClientSocketHandle handle;
2162 TestCompletionCallback callback; 2161 TestCompletionCallback callback;
2163 EXPECT_EQ(ERR_IO_PENDING, 2162 EXPECT_EQ(ERR_IO_PENDING,
2164 handle.Init("a", 2163 handle.Init("a",
2165 params_, 2164 params_,
2166 kDefaultPriority, 2165 DEFAULT_PRIORITY,
2167 callback.callback(), 2166 callback.callback(),
2168 pool_.get(), 2167 pool_.get(),
2169 BoundNetLog())); 2168 BoundNetLog()));
2170 EXPECT_EQ(LOAD_STATE_CONNECTING, pool_->GetLoadState("a", &handle)); 2169 EXPECT_EQ(LOAD_STATE_CONNECTING, pool_->GetLoadState("a", &handle));
2171 EXPECT_EQ(ERR_CONNECTION_FAILED, callback.WaitForResult()); 2170 EXPECT_EQ(ERR_CONNECTION_FAILED, callback.WaitForResult());
2172 EXPECT_FALSE(handle.is_initialized()); 2171 EXPECT_FALSE(handle.is_initialized());
2173 EXPECT_FALSE(handle.socket()); 2172 EXPECT_FALSE(handle.socket());
2174 EXPECT_TRUE(handle.is_ssl_error()); 2173 EXPECT_TRUE(handle.is_ssl_error());
2175 EXPECT_FALSE(handle.ssl_error_response_info().headers.get() == NULL); 2174 EXPECT_FALSE(handle.ssl_error_response_info().headers.get() == NULL);
2176 } 2175 }
(...skipping 347 matching lines...) Expand 10 before | Expand all | Expand 10 after
2524 EXPECT_EQ(OK, callback_a[i].WaitForResult()); 2523 EXPECT_EQ(OK, callback_a[i].WaitForResult());
2525 } 2524 }
2526 } 2525 }
2527 2526
2528 TEST_F(ClientSocketPoolBaseTest, 2527 TEST_F(ClientSocketPoolBaseTest,
2529 ReleasingDisconnectedSocketsMaintainsPriorityOrder) { 2528 ReleasingDisconnectedSocketsMaintainsPriorityOrder) {
2530 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2529 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2531 2530
2532 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 2531 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
2533 2532
2534 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 2533 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
2535 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 2534 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
2536 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 2535 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
2537 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", kDefaultPriority)); 2536 EXPECT_EQ(ERR_IO_PENDING, StartRequest("a", DEFAULT_PRIORITY));
2538 2537
2539 EXPECT_EQ(OK, (*requests())[0]->WaitForResult()); 2538 EXPECT_EQ(OK, (*requests())[0]->WaitForResult());
2540 EXPECT_EQ(OK, (*requests())[1]->WaitForResult()); 2539 EXPECT_EQ(OK, (*requests())[1]->WaitForResult());
2541 EXPECT_EQ(2u, completion_count()); 2540 EXPECT_EQ(2u, completion_count());
2542 2541
2543 // Releases one connection. 2542 // Releases one connection.
2544 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::NO_KEEP_ALIVE)); 2543 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::NO_KEEP_ALIVE));
2545 EXPECT_EQ(OK, (*requests())[2]->WaitForResult()); 2544 EXPECT_EQ(OK, (*requests())[2]->WaitForResult());
2546 2545
2547 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::NO_KEEP_ALIVE)); 2546 EXPECT_TRUE(ReleaseOneConnection(ClientSocketPoolTest::NO_KEEP_ALIVE));
(...skipping 26 matching lines...) Expand all
2574 ClientSocketHandle* handle() { return &handle_; } 2573 ClientSocketHandle* handle() { return &handle_; }
2575 2574
2576 const CompletionCallback& callback() const { return callback_; } 2575 const CompletionCallback& callback() const { return callback_; }
2577 2576
2578 private: 2577 private:
2579 void OnComplete(int result) { 2578 void OnComplete(int result) {
2580 SetResult(result); 2579 SetResult(result);
2581 if (reset_releasing_handle_) 2580 if (reset_releasing_handle_)
2582 handle_.Reset(); 2581 handle_.Reset();
2583 2582
2584 scoped_refptr<TestSocketParams> con_params(new TestSocketParams()); 2583 scoped_refptr<TestSocketParams> con_params(
2584 new TestSocketParams(RESPECT_LIMITS));
2585 EXPECT_EQ(expected_result_, 2585 EXPECT_EQ(expected_result_,
2586 handle2_.Init("a", con_params, kDefaultPriority, 2586 handle2_.Init("a", con_params, DEFAULT_PRIORITY,
2587 callback2_.callback(), pool_, BoundNetLog())); 2587 callback2_.callback(), pool_, BoundNetLog()));
2588 } 2588 }
2589 2589
2590 TestClientSocketPool* const pool_; 2590 TestClientSocketPool* const pool_;
2591 int expected_result_; 2591 int expected_result_;
2592 bool reset_releasing_handle_; 2592 bool reset_releasing_handle_;
2593 ClientSocketHandle handle_; 2593 ClientSocketHandle handle_;
2594 ClientSocketHandle handle2_; 2594 ClientSocketHandle handle2_;
2595 CompletionCallback callback_; 2595 CompletionCallback callback_;
2596 TestCompletionCallback callback2_; 2596 TestCompletionCallback callback2_;
2597 }; 2597 };
2598 2598
2599 2599
2600 TEST_F(ClientSocketPoolBaseTest, AdditionalErrorSocketsDontUseSlot) { 2600 TEST_F(ClientSocketPoolBaseTest, AdditionalErrorSocketsDontUseSlot) {
2601 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2601 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2602 2602
2603 EXPECT_EQ(OK, StartRequest("b", kDefaultPriority)); 2603 EXPECT_EQ(OK, StartRequest("b", DEFAULT_PRIORITY));
2604 EXPECT_EQ(OK, StartRequest("a", kDefaultPriority)); 2604 EXPECT_EQ(OK, StartRequest("a", DEFAULT_PRIORITY));
2605 EXPECT_EQ(OK, StartRequest("b", kDefaultPriority)); 2605 EXPECT_EQ(OK, StartRequest("b", DEFAULT_PRIORITY));
2606 2606
2607 EXPECT_EQ(static_cast<int>(requests_size()), 2607 EXPECT_EQ(static_cast<int>(requests_size()),
2608 client_socket_factory_.allocation_count()); 2608 client_socket_factory_.allocation_count());
2609 2609
2610 connect_job_factory_->set_job_type( 2610 connect_job_factory_->set_job_type(
2611 TestConnectJob::kMockPendingAdditionalErrorStateJob); 2611 TestConnectJob::kMockPendingAdditionalErrorStateJob);
2612 TestReleasingSocketRequest req(pool_.get(), OK, false); 2612 TestReleasingSocketRequest req(pool_.get(), OK, false);
2613 EXPECT_EQ(ERR_IO_PENDING, 2613 EXPECT_EQ(ERR_IO_PENDING,
2614 req.handle()->Init("a", params_, kDefaultPriority, req.callback(), 2614 req.handle()->Init("a", params_, DEFAULT_PRIORITY, req.callback(),
2615 pool_.get(), BoundNetLog())); 2615 pool_.get(), BoundNetLog()));
2616 // The next job should complete synchronously 2616 // The next job should complete synchronously
2617 connect_job_factory_->set_job_type(TestConnectJob::kMockJob); 2617 connect_job_factory_->set_job_type(TestConnectJob::kMockJob);
2618 2618
2619 EXPECT_EQ(ERR_CONNECTION_FAILED, req.WaitForResult()); 2619 EXPECT_EQ(ERR_CONNECTION_FAILED, req.WaitForResult());
2620 EXPECT_FALSE(req.handle()->is_initialized()); 2620 EXPECT_FALSE(req.handle()->is_initialized());
2621 EXPECT_FALSE(req.handle()->socket()); 2621 EXPECT_FALSE(req.handle()->socket());
2622 EXPECT_TRUE(req.handle()->is_ssl_error()); 2622 EXPECT_TRUE(req.handle()->is_ssl_error());
2623 EXPECT_FALSE(req.handle()->ssl_error_response_info().headers.get() == NULL); 2623 EXPECT_FALSE(req.handle()->ssl_error_response_info().headers.get() == NULL);
2624 } 2624 }
2625 2625
2626 // http://crbug.com/44724 regression test. 2626 // http://crbug.com/44724 regression test.
2627 // We start releasing the pool when we flush on network change. When that 2627 // We start releasing the pool when we flush on network change. When that
2628 // happens, the only active references are in the ClientSocketHandles. When a 2628 // happens, the only active references are in the ClientSocketHandles. When a
2629 // ConnectJob completes and calls back into the last ClientSocketHandle, that 2629 // ConnectJob completes and calls back into the last ClientSocketHandle, that
2630 // callback can release the last reference and delete the pool. After the 2630 // callback can release the last reference and delete the pool. After the
2631 // callback finishes, we go back to the stack frame within the now-deleted pool. 2631 // callback finishes, we go back to the stack frame within the now-deleted pool.
2632 // Executing any code that refers to members of the now-deleted pool can cause 2632 // Executing any code that refers to members of the now-deleted pool can cause
2633 // crashes. 2633 // crashes.
2634 TEST_F(ClientSocketPoolBaseTest, CallbackThatReleasesPool) { 2634 TEST_F(ClientSocketPoolBaseTest, CallbackThatReleasesPool) {
2635 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2635 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2636 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingFailingJob); 2636 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingFailingJob);
2637 2637
2638 ClientSocketHandle handle; 2638 ClientSocketHandle handle;
2639 TestCompletionCallback callback; 2639 TestCompletionCallback callback;
2640 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 2640 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
2641 params_, 2641 params_,
2642 kDefaultPriority, 2642 DEFAULT_PRIORITY,
2643 callback.callback(), 2643 callback.callback(),
2644 pool_.get(), 2644 pool_.get(),
2645 BoundNetLog())); 2645 BoundNetLog()));
2646 2646
2647 pool_->FlushWithError(ERR_NETWORK_CHANGED); 2647 pool_->FlushWithError(ERR_NETWORK_CHANGED);
2648 2648
2649 // We'll call back into this now. 2649 // We'll call back into this now.
2650 callback.WaitForResult(); 2650 callback.WaitForResult();
2651 } 2651 }
2652 2652
2653 TEST_F(ClientSocketPoolBaseTest, DoNotReuseSocketAfterFlush) { 2653 TEST_F(ClientSocketPoolBaseTest, DoNotReuseSocketAfterFlush) {
2654 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2654 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2655 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 2655 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
2656 2656
2657 ClientSocketHandle handle; 2657 ClientSocketHandle handle;
2658 TestCompletionCallback callback; 2658 TestCompletionCallback callback;
2659 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 2659 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
2660 params_, 2660 params_,
2661 kDefaultPriority, 2661 DEFAULT_PRIORITY,
2662 callback.callback(), 2662 callback.callback(),
2663 pool_.get(), 2663 pool_.get(),
2664 BoundNetLog())); 2664 BoundNetLog()));
2665 EXPECT_EQ(OK, callback.WaitForResult()); 2665 EXPECT_EQ(OK, callback.WaitForResult());
2666 EXPECT_EQ(ClientSocketHandle::UNUSED, handle.reuse_type()); 2666 EXPECT_EQ(ClientSocketHandle::UNUSED, handle.reuse_type());
2667 2667
2668 pool_->FlushWithError(ERR_NETWORK_CHANGED); 2668 pool_->FlushWithError(ERR_NETWORK_CHANGED);
2669 2669
2670 handle.Reset(); 2670 handle.Reset();
2671 base::MessageLoop::current()->RunUntilIdle(); 2671 base::MessageLoop::current()->RunUntilIdle();
2672 2672
2673 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 2673 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
2674 params_, 2674 params_,
2675 kDefaultPriority, 2675 DEFAULT_PRIORITY,
2676 callback.callback(), 2676 callback.callback(),
2677 pool_.get(), 2677 pool_.get(),
2678 BoundNetLog())); 2678 BoundNetLog()));
2679 EXPECT_EQ(OK, callback.WaitForResult()); 2679 EXPECT_EQ(OK, callback.WaitForResult());
2680 EXPECT_EQ(ClientSocketHandle::UNUSED, handle.reuse_type()); 2680 EXPECT_EQ(ClientSocketHandle::UNUSED, handle.reuse_type());
2681 } 2681 }
2682 2682
2683 class ConnectWithinCallback : public TestCompletionCallbackBase { 2683 class ConnectWithinCallback : public TestCompletionCallbackBase {
2684 public: 2684 public:
2685 ConnectWithinCallback( 2685 ConnectWithinCallback(
(...skipping 14 matching lines...) Expand all
2700 } 2700 }
2701 2701
2702 const CompletionCallback& callback() const { return callback_; } 2702 const CompletionCallback& callback() const { return callback_; }
2703 2703
2704 private: 2704 private:
2705 void OnComplete(int result) { 2705 void OnComplete(int result) {
2706 SetResult(result); 2706 SetResult(result);
2707 EXPECT_EQ(ERR_IO_PENDING, 2707 EXPECT_EQ(ERR_IO_PENDING,
2708 handle_.Init(group_name_, 2708 handle_.Init(group_name_,
2709 params_, 2709 params_,
2710 kDefaultPriority, 2710 DEFAULT_PRIORITY,
2711 nested_callback_.callback(), 2711 nested_callback_.callback(),
2712 pool_, 2712 pool_,
2713 BoundNetLog())); 2713 BoundNetLog()));
2714 } 2714 }
2715 2715
2716 const std::string group_name_; 2716 const std::string group_name_;
2717 const scoped_refptr<TestSocketParams> params_; 2717 const scoped_refptr<TestSocketParams> params_;
2718 TestClientSocketPool* const pool_; 2718 TestClientSocketPool* const pool_;
2719 ClientSocketHandle handle_; 2719 ClientSocketHandle handle_;
2720 CompletionCallback callback_; 2720 CompletionCallback callback_;
2721 TestCompletionCallback nested_callback_; 2721 TestCompletionCallback nested_callback_;
2722 2722
2723 DISALLOW_COPY_AND_ASSIGN(ConnectWithinCallback); 2723 DISALLOW_COPY_AND_ASSIGN(ConnectWithinCallback);
2724 }; 2724 };
2725 2725
2726 TEST_F(ClientSocketPoolBaseTest, AbortAllRequestsOnFlush) { 2726 TEST_F(ClientSocketPoolBaseTest, AbortAllRequestsOnFlush) {
2727 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2727 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2728 2728
2729 // First job will be waiting until it gets aborted. 2729 // First job will be waiting until it gets aborted.
2730 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 2730 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
2731 2731
2732 ClientSocketHandle handle; 2732 ClientSocketHandle handle;
2733 ConnectWithinCallback callback("a", params_, pool_.get()); 2733 ConnectWithinCallback callback("a", params_, pool_.get());
2734 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 2734 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
2735 params_, 2735 params_,
2736 kDefaultPriority, 2736 DEFAULT_PRIORITY,
2737 callback.callback(), 2737 callback.callback(),
2738 pool_.get(), 2738 pool_.get(),
2739 BoundNetLog())); 2739 BoundNetLog()));
2740 2740
2741 // Second job will be started during the first callback, and will 2741 // Second job will be started during the first callback, and will
2742 // asynchronously complete with OK. 2742 // asynchronously complete with OK.
2743 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 2743 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
2744 pool_->FlushWithError(ERR_NETWORK_CHANGED); 2744 pool_->FlushWithError(ERR_NETWORK_CHANGED);
2745 EXPECT_EQ(ERR_NETWORK_CHANGED, callback.WaitForResult()); 2745 EXPECT_EQ(ERR_NETWORK_CHANGED, callback.WaitForResult());
2746 EXPECT_EQ(OK, callback.WaitForNestedResult()); 2746 EXPECT_EQ(OK, callback.WaitForNestedResult());
2747 } 2747 }
2748 2748
2749 // Cancel a pending socket request while we're at max sockets, 2749 // Cancel a pending socket request while we're at max sockets,
2750 // and verify that the backup socket firing doesn't cause a crash. 2750 // and verify that the backup socket firing doesn't cause a crash.
2751 TEST_F(ClientSocketPoolBaseTest, BackupSocketCancelAtMaxSockets) { 2751 TEST_F(ClientSocketPoolBaseTest, BackupSocketCancelAtMaxSockets) {
2752 // Max 4 sockets globally, max 4 sockets per group. 2752 // Max 4 sockets globally, max 4 sockets per group.
2753 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets); 2753 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets);
2754 pool_->EnableConnectBackupJobs(); 2754 pool_->EnableConnectBackupJobs();
2755 2755
2756 // Create the first socket and set to ERR_IO_PENDING. This starts the backup 2756 // Create the first socket and set to ERR_IO_PENDING. This starts the backup
2757 // timer. 2757 // timer.
2758 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 2758 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
2759 ClientSocketHandle handle; 2759 ClientSocketHandle handle;
2760 TestCompletionCallback callback; 2760 TestCompletionCallback callback;
2761 EXPECT_EQ(ERR_IO_PENDING, handle.Init("bar", 2761 EXPECT_EQ(ERR_IO_PENDING, handle.Init("bar",
2762 params_, 2762 params_,
2763 kDefaultPriority, 2763 DEFAULT_PRIORITY,
2764 callback.callback(), 2764 callback.callback(),
2765 pool_.get(), 2765 pool_.get(),
2766 BoundNetLog())); 2766 BoundNetLog()));
2767 2767
2768 // Start (MaxSockets - 1) connected sockets to reach max sockets. 2768 // Start (MaxSockets - 1) connected sockets to reach max sockets.
2769 connect_job_factory_->set_job_type(TestConnectJob::kMockJob); 2769 connect_job_factory_->set_job_type(TestConnectJob::kMockJob);
2770 ClientSocketHandle handles[kDefaultMaxSockets]; 2770 ClientSocketHandle handles[kDefaultMaxSockets];
2771 for (int i = 1; i < kDefaultMaxSockets; ++i) { 2771 for (int i = 1; i < kDefaultMaxSockets; ++i) {
2772 TestCompletionCallback callback; 2772 TestCompletionCallback callback;
2773 EXPECT_EQ(OK, handles[i].Init("bar", 2773 EXPECT_EQ(OK, handles[i].Init("bar",
2774 params_, 2774 params_,
2775 kDefaultPriority, 2775 DEFAULT_PRIORITY,
2776 callback.callback(), 2776 callback.callback(),
2777 pool_.get(), 2777 pool_.get(),
2778 BoundNetLog())); 2778 BoundNetLog()));
2779 } 2779 }
2780 2780
2781 base::MessageLoop::current()->RunUntilIdle(); 2781 base::MessageLoop::current()->RunUntilIdle();
2782 2782
2783 // Cancel the pending request. 2783 // Cancel the pending request.
2784 handle.Reset(); 2784 handle.Reset();
2785 2785
2786 // Wait for the backup timer to fire (add some slop to ensure it fires) 2786 // Wait for the backup timer to fire (add some slop to ensure it fires)
2787 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds( 2787 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(
2788 ClientSocketPool::kMaxConnectRetryIntervalMs / 2 * 3)); 2788 ClientSocketPool::kMaxConnectRetryIntervalMs / 2 * 3));
2789 2789
2790 base::MessageLoop::current()->RunUntilIdle(); 2790 base::MessageLoop::current()->RunUntilIdle();
2791 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count()); 2791 EXPECT_EQ(kDefaultMaxSockets, client_socket_factory_.allocation_count());
2792 } 2792 }
2793 2793
2794 TEST_F(ClientSocketPoolBaseTest, CancelBackupSocketAfterCancelingAllRequests) { 2794 TEST_F(ClientSocketPoolBaseTest, CancelBackupSocketAfterCancelingAllRequests) {
2795 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets); 2795 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets);
2796 pool_->EnableConnectBackupJobs(); 2796 pool_->EnableConnectBackupJobs();
2797 2797
2798 // Create the first socket and set to ERR_IO_PENDING. This starts the backup 2798 // Create the first socket and set to ERR_IO_PENDING. This starts the backup
2799 // timer. 2799 // timer.
2800 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 2800 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
2801 ClientSocketHandle handle; 2801 ClientSocketHandle handle;
2802 TestCompletionCallback callback; 2802 TestCompletionCallback callback;
2803 EXPECT_EQ(ERR_IO_PENDING, handle.Init("bar", 2803 EXPECT_EQ(ERR_IO_PENDING, handle.Init("bar",
2804 params_, 2804 params_,
2805 kDefaultPriority, 2805 DEFAULT_PRIORITY,
2806 callback.callback(), 2806 callback.callback(),
2807 pool_.get(), 2807 pool_.get(),
2808 BoundNetLog())); 2808 BoundNetLog()));
2809 ASSERT_TRUE(pool_->HasGroup("bar")); 2809 ASSERT_TRUE(pool_->HasGroup("bar"));
2810 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("bar")); 2810 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("bar"));
2811 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("bar")); 2811 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("bar"));
2812 2812
2813 // Cancel the socket request. This should cancel the backup timer. Wait for 2813 // Cancel the socket request. This should cancel the backup timer. Wait for
2814 // the backup time to see if it indeed got canceled. 2814 // the backup time to see if it indeed got canceled.
2815 handle.Reset(); 2815 handle.Reset();
2816 // Wait for the backup timer to fire (add some slop to ensure it fires) 2816 // Wait for the backup timer to fire (add some slop to ensure it fires)
2817 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds( 2817 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(
2818 ClientSocketPool::kMaxConnectRetryIntervalMs / 2 * 3)); 2818 ClientSocketPool::kMaxConnectRetryIntervalMs / 2 * 3));
2819 base::MessageLoop::current()->RunUntilIdle(); 2819 base::MessageLoop::current()->RunUntilIdle();
2820 ASSERT_TRUE(pool_->HasGroup("bar")); 2820 ASSERT_TRUE(pool_->HasGroup("bar"));
2821 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("bar")); 2821 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("bar"));
2822 } 2822 }
2823 2823
2824 TEST_F(ClientSocketPoolBaseTest, CancelBackupSocketAfterFinishingAllRequests) { 2824 TEST_F(ClientSocketPoolBaseTest, CancelBackupSocketAfterFinishingAllRequests) {
2825 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets); 2825 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets);
2826 pool_->EnableConnectBackupJobs(); 2826 pool_->EnableConnectBackupJobs();
2827 2827
2828 // Create the first socket and set to ERR_IO_PENDING. This starts the backup 2828 // Create the first socket and set to ERR_IO_PENDING. This starts the backup
2829 // timer. 2829 // timer.
2830 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 2830 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
2831 ClientSocketHandle handle; 2831 ClientSocketHandle handle;
2832 TestCompletionCallback callback; 2832 TestCompletionCallback callback;
2833 EXPECT_EQ(ERR_IO_PENDING, handle.Init("bar", 2833 EXPECT_EQ(ERR_IO_PENDING, handle.Init("bar",
2834 params_, 2834 params_,
2835 kDefaultPriority, 2835 DEFAULT_PRIORITY,
2836 callback.callback(), 2836 callback.callback(),
2837 pool_.get(), 2837 pool_.get(),
2838 BoundNetLog())); 2838 BoundNetLog()));
2839 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 2839 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
2840 ClientSocketHandle handle2; 2840 ClientSocketHandle handle2;
2841 TestCompletionCallback callback2; 2841 TestCompletionCallback callback2;
2842 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("bar", 2842 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("bar",
2843 params_, 2843 params_,
2844 kDefaultPriority, 2844 DEFAULT_PRIORITY,
2845 callback2.callback(), 2845 callback2.callback(),
2846 pool_.get(), 2846 pool_.get(),
2847 BoundNetLog())); 2847 BoundNetLog()));
2848 ASSERT_TRUE(pool_->HasGroup("bar")); 2848 ASSERT_TRUE(pool_->HasGroup("bar"));
2849 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("bar")); 2849 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("bar"));
2850 2850
2851 // Cancel request 1 and then complete request 2. With the requests finished, 2851 // Cancel request 1 and then complete request 2. With the requests finished,
2852 // the backup timer should be cancelled. 2852 // the backup timer should be cancelled.
2853 handle.Reset(); 2853 handle.Reset();
2854 EXPECT_EQ(OK, callback2.WaitForResult()); 2854 EXPECT_EQ(OK, callback2.WaitForResult());
2855 // Wait for the backup timer to fire (add some slop to ensure it fires) 2855 // Wait for the backup timer to fire (add some slop to ensure it fires)
2856 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds( 2856 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(
2857 ClientSocketPool::kMaxConnectRetryIntervalMs / 2 * 3)); 2857 ClientSocketPool::kMaxConnectRetryIntervalMs / 2 * 3));
2858 base::MessageLoop::current()->RunUntilIdle(); 2858 base::MessageLoop::current()->RunUntilIdle();
2859 } 2859 }
2860 2860
2861 // Test delayed socket binding for the case where we have two connects, 2861 // Test delayed socket binding for the case where we have two connects,
2862 // and while one is waiting on a connect, the other frees up. 2862 // and while one is waiting on a connect, the other frees up.
2863 // The socket waiting on a connect should switch immediately to the freed 2863 // The socket waiting on a connect should switch immediately to the freed
2864 // up socket. 2864 // up socket.
2865 TEST_F(ClientSocketPoolBaseTest, DelayedSocketBindingWaitingForConnect) { 2865 TEST_F(ClientSocketPoolBaseTest, DelayedSocketBindingWaitingForConnect) {
2866 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2866 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2867 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 2867 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
2868 2868
2869 ClientSocketHandle handle1; 2869 ClientSocketHandle handle1;
2870 TestCompletionCallback callback; 2870 TestCompletionCallback callback;
2871 EXPECT_EQ(ERR_IO_PENDING, 2871 EXPECT_EQ(ERR_IO_PENDING,
2872 handle1.Init("a", 2872 handle1.Init("a",
2873 params_, 2873 params_,
2874 kDefaultPriority, 2874 DEFAULT_PRIORITY,
2875 callback.callback(), 2875 callback.callback(),
2876 pool_.get(), 2876 pool_.get(),
2877 BoundNetLog())); 2877 BoundNetLog()));
2878 EXPECT_EQ(OK, callback.WaitForResult()); 2878 EXPECT_EQ(OK, callback.WaitForResult());
2879 2879
2880 // No idle sockets, no pending jobs. 2880 // No idle sockets, no pending jobs.
2881 EXPECT_EQ(0, pool_->IdleSocketCount()); 2881 EXPECT_EQ(0, pool_->IdleSocketCount());
2882 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 2882 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
2883 2883
2884 // Create a second socket to the same host, but this one will wait. 2884 // Create a second socket to the same host, but this one will wait.
2885 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 2885 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
2886 ClientSocketHandle handle2; 2886 ClientSocketHandle handle2;
2887 EXPECT_EQ(ERR_IO_PENDING, 2887 EXPECT_EQ(ERR_IO_PENDING,
2888 handle2.Init("a", 2888 handle2.Init("a",
2889 params_, 2889 params_,
2890 kDefaultPriority, 2890 DEFAULT_PRIORITY,
2891 callback.callback(), 2891 callback.callback(),
2892 pool_.get(), 2892 pool_.get(),
2893 BoundNetLog())); 2893 BoundNetLog()));
2894 // No idle sockets, and one connecting job. 2894 // No idle sockets, and one connecting job.
2895 EXPECT_EQ(0, pool_->IdleSocketCount()); 2895 EXPECT_EQ(0, pool_->IdleSocketCount());
2896 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 2896 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
2897 2897
2898 // Return the first handle to the pool. This will initiate the delayed 2898 // Return the first handle to the pool. This will initiate the delayed
2899 // binding. 2899 // binding.
2900 handle1.Reset(); 2900 handle1.Reset();
(...skipping 21 matching lines...) Expand all
2922 // of the group's sockets frees up. 2922 // of the group's sockets frees up.
2923 TEST_F(ClientSocketPoolBaseTest, DelayedSocketBindingAtGroupCapacity) { 2923 TEST_F(ClientSocketPoolBaseTest, DelayedSocketBindingAtGroupCapacity) {
2924 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2924 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2925 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 2925 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
2926 2926
2927 ClientSocketHandle handle1; 2927 ClientSocketHandle handle1;
2928 TestCompletionCallback callback; 2928 TestCompletionCallback callback;
2929 EXPECT_EQ(ERR_IO_PENDING, 2929 EXPECT_EQ(ERR_IO_PENDING,
2930 handle1.Init("a", 2930 handle1.Init("a",
2931 params_, 2931 params_,
2932 kDefaultPriority, 2932 DEFAULT_PRIORITY,
2933 callback.callback(), 2933 callback.callback(),
2934 pool_.get(), 2934 pool_.get(),
2935 BoundNetLog())); 2935 BoundNetLog()));
2936 EXPECT_EQ(OK, callback.WaitForResult()); 2936 EXPECT_EQ(OK, callback.WaitForResult());
2937 2937
2938 // No idle sockets, no pending jobs. 2938 // No idle sockets, no pending jobs.
2939 EXPECT_EQ(0, pool_->IdleSocketCount()); 2939 EXPECT_EQ(0, pool_->IdleSocketCount());
2940 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 2940 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
2941 2941
2942 // Create a second socket to the same host, but this one will wait. 2942 // Create a second socket to the same host, but this one will wait.
2943 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 2943 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
2944 ClientSocketHandle handle2; 2944 ClientSocketHandle handle2;
2945 EXPECT_EQ(ERR_IO_PENDING, 2945 EXPECT_EQ(ERR_IO_PENDING,
2946 handle2.Init("a", 2946 handle2.Init("a",
2947 params_, 2947 params_,
2948 kDefaultPriority, 2948 DEFAULT_PRIORITY,
2949 callback.callback(), 2949 callback.callback(),
2950 pool_.get(), 2950 pool_.get(),
2951 BoundNetLog())); 2951 BoundNetLog()));
2952 // No idle sockets, and one connecting job. 2952 // No idle sockets, and one connecting job.
2953 EXPECT_EQ(0, pool_->IdleSocketCount()); 2953 EXPECT_EQ(0, pool_->IdleSocketCount());
2954 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 2954 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
2955 2955
2956 // Return the first handle to the pool. This will initiate the delayed 2956 // Return the first handle to the pool. This will initiate the delayed
2957 // binding. 2957 // binding.
2958 handle1.Reset(); 2958 handle1.Reset();
(...skipping 23 matching lines...) Expand all
2982 // should complete, by taking the first socket's idle socket. 2982 // should complete, by taking the first socket's idle socket.
2983 TEST_F(ClientSocketPoolBaseTest, DelayedSocketBindingAtStall) { 2983 TEST_F(ClientSocketPoolBaseTest, DelayedSocketBindingAtStall) {
2984 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 2984 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
2985 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 2985 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
2986 2986
2987 ClientSocketHandle handle1; 2987 ClientSocketHandle handle1;
2988 TestCompletionCallback callback; 2988 TestCompletionCallback callback;
2989 EXPECT_EQ(ERR_IO_PENDING, 2989 EXPECT_EQ(ERR_IO_PENDING,
2990 handle1.Init("a", 2990 handle1.Init("a",
2991 params_, 2991 params_,
2992 kDefaultPriority, 2992 DEFAULT_PRIORITY,
2993 callback.callback(), 2993 callback.callback(),
2994 pool_.get(), 2994 pool_.get(),
2995 BoundNetLog())); 2995 BoundNetLog()));
2996 EXPECT_EQ(OK, callback.WaitForResult()); 2996 EXPECT_EQ(OK, callback.WaitForResult());
2997 2997
2998 // No idle sockets, no pending jobs. 2998 // No idle sockets, no pending jobs.
2999 EXPECT_EQ(0, pool_->IdleSocketCount()); 2999 EXPECT_EQ(0, pool_->IdleSocketCount());
3000 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 3000 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
3001 3001
3002 // Create a second socket to the same host, but this one will wait. 3002 // Create a second socket to the same host, but this one will wait.
3003 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob); 3003 connect_job_factory_->set_job_type(TestConnectJob::kMockWaitingJob);
3004 ClientSocketHandle handle2; 3004 ClientSocketHandle handle2;
3005 EXPECT_EQ(ERR_IO_PENDING, 3005 EXPECT_EQ(ERR_IO_PENDING,
3006 handle2.Init("a", 3006 handle2.Init("a",
3007 params_, 3007 params_,
3008 kDefaultPriority, 3008 DEFAULT_PRIORITY,
3009 callback.callback(), 3009 callback.callback(),
3010 pool_.get(), 3010 pool_.get(),
3011 BoundNetLog())); 3011 BoundNetLog()));
3012 // No idle sockets, and one connecting job. 3012 // No idle sockets, and one connecting job.
3013 EXPECT_EQ(0, pool_->IdleSocketCount()); 3013 EXPECT_EQ(0, pool_->IdleSocketCount());
3014 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 3014 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
3015 3015
3016 // Return the first handle to the pool. This will initiate the delayed 3016 // Return the first handle to the pool. This will initiate the delayed
3017 // binding. 3017 // binding.
3018 handle1.Reset(); 3018 handle1.Reset();
(...skipping 26 matching lines...) Expand all
3045 3045
3046 // Make the first request asynchronous fail. 3046 // Make the first request asynchronous fail.
3047 // This will free up a socket slot later. 3047 // This will free up a socket slot later.
3048 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingFailingJob); 3048 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingFailingJob);
3049 3049
3050 ClientSocketHandle handle1; 3050 ClientSocketHandle handle1;
3051 TestCompletionCallback callback1; 3051 TestCompletionCallback callback1;
3052 EXPECT_EQ(ERR_IO_PENDING, 3052 EXPECT_EQ(ERR_IO_PENDING,
3053 handle1.Init("a", 3053 handle1.Init("a",
3054 params_, 3054 params_,
3055 kDefaultPriority, 3055 DEFAULT_PRIORITY,
3056 callback1.callback(), 3056 callback1.callback(),
3057 pool_.get(), 3057 pool_.get(),
3058 BoundNetLog())); 3058 BoundNetLog()));
3059 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 3059 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
3060 3060
3061 // Make the second request synchronously fail. This should make the Group 3061 // Make the second request synchronously fail. This should make the Group
3062 // empty. 3062 // empty.
3063 connect_job_factory_->set_job_type(TestConnectJob::kMockFailingJob); 3063 connect_job_factory_->set_job_type(TestConnectJob::kMockFailingJob);
3064 ClientSocketHandle handle2; 3064 ClientSocketHandle handle2;
3065 TestCompletionCallback callback2; 3065 TestCompletionCallback callback2;
3066 // It'll be ERR_IO_PENDING now, but the TestConnectJob will synchronously fail 3066 // It'll be ERR_IO_PENDING now, but the TestConnectJob will synchronously fail
3067 // when created. 3067 // when created.
3068 EXPECT_EQ(ERR_IO_PENDING, 3068 EXPECT_EQ(ERR_IO_PENDING,
3069 handle2.Init("a", 3069 handle2.Init("a",
3070 params_, 3070 params_,
3071 kDefaultPriority, 3071 DEFAULT_PRIORITY,
3072 callback2.callback(), 3072 callback2.callback(),
3073 pool_.get(), 3073 pool_.get(),
3074 BoundNetLog())); 3074 BoundNetLog()));
3075 3075
3076 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 3076 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
3077 3077
3078 EXPECT_EQ(ERR_CONNECTION_FAILED, callback1.WaitForResult()); 3078 EXPECT_EQ(ERR_CONNECTION_FAILED, callback1.WaitForResult());
3079 EXPECT_EQ(ERR_CONNECTION_FAILED, callback2.WaitForResult()); 3079 EXPECT_EQ(ERR_CONNECTION_FAILED, callback2.WaitForResult());
3080 EXPECT_FALSE(pool_->HasGroup("a")); 3080 EXPECT_FALSE(pool_->HasGroup("a"));
3081 } 3081 }
3082 3082
3083 TEST_F(ClientSocketPoolBaseTest, PreferUsedSocketToUnusedSocket) { 3083 TEST_F(ClientSocketPoolBaseTest, PreferUsedSocketToUnusedSocket) {
3084 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets); 3084 CreatePool(kDefaultMaxSockets, kDefaultMaxSockets);
3085 3085
3086 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 3086 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
3087 3087
3088 ClientSocketHandle handle1; 3088 ClientSocketHandle handle1;
3089 TestCompletionCallback callback1; 3089 TestCompletionCallback callback1;
3090 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a", 3090 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a",
3091 params_, 3091 params_,
3092 kDefaultPriority, 3092 DEFAULT_PRIORITY,
3093 callback1.callback(), 3093 callback1.callback(),
3094 pool_.get(), 3094 pool_.get(),
3095 BoundNetLog())); 3095 BoundNetLog()));
3096 3096
3097 ClientSocketHandle handle2; 3097 ClientSocketHandle handle2;
3098 TestCompletionCallback callback2; 3098 TestCompletionCallback callback2;
3099 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("a", 3099 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("a",
3100 params_, 3100 params_,
3101 kDefaultPriority, 3101 DEFAULT_PRIORITY,
3102 callback2.callback(), 3102 callback2.callback(),
3103 pool_.get(), 3103 pool_.get(),
3104 BoundNetLog())); 3104 BoundNetLog()));
3105 ClientSocketHandle handle3; 3105 ClientSocketHandle handle3;
3106 TestCompletionCallback callback3; 3106 TestCompletionCallback callback3;
3107 EXPECT_EQ(ERR_IO_PENDING, handle3.Init("a", 3107 EXPECT_EQ(ERR_IO_PENDING, handle3.Init("a",
3108 params_, 3108 params_,
3109 kDefaultPriority, 3109 DEFAULT_PRIORITY,
3110 callback3.callback(), 3110 callback3.callback(),
3111 pool_.get(), 3111 pool_.get(),
3112 BoundNetLog())); 3112 BoundNetLog()));
3113 3113
3114 EXPECT_EQ(OK, callback1.WaitForResult()); 3114 EXPECT_EQ(OK, callback1.WaitForResult());
3115 EXPECT_EQ(OK, callback2.WaitForResult()); 3115 EXPECT_EQ(OK, callback2.WaitForResult());
3116 EXPECT_EQ(OK, callback3.WaitForResult()); 3116 EXPECT_EQ(OK, callback3.WaitForResult());
3117 3117
3118 // Use the socket. 3118 // Use the socket.
3119 EXPECT_EQ(1, handle1.socket()->Write(NULL, 1, CompletionCallback())); 3119 EXPECT_EQ(1, handle1.socket()->Write(NULL, 1, CompletionCallback()));
3120 EXPECT_EQ(1, handle3.socket()->Write(NULL, 1, CompletionCallback())); 3120 EXPECT_EQ(1, handle3.socket()->Write(NULL, 1, CompletionCallback()));
3121 3121
3122 handle1.Reset(); 3122 handle1.Reset();
3123 handle2.Reset(); 3123 handle2.Reset();
3124 handle3.Reset(); 3124 handle3.Reset();
3125 3125
3126 EXPECT_EQ(OK, handle1.Init("a", 3126 EXPECT_EQ(OK, handle1.Init("a",
3127 params_, 3127 params_,
3128 kDefaultPriority, 3128 DEFAULT_PRIORITY,
3129 callback1.callback(), 3129 callback1.callback(),
3130 pool_.get(), 3130 pool_.get(),
3131 BoundNetLog())); 3131 BoundNetLog()));
3132 EXPECT_EQ(OK, handle2.Init("a", 3132 EXPECT_EQ(OK, handle2.Init("a",
3133 params_, 3133 params_,
3134 kDefaultPriority, 3134 DEFAULT_PRIORITY,
3135 callback2.callback(), 3135 callback2.callback(),
3136 pool_.get(), 3136 pool_.get(),
3137 BoundNetLog())); 3137 BoundNetLog()));
3138 EXPECT_EQ(OK, handle3.Init("a", 3138 EXPECT_EQ(OK, handle3.Init("a",
3139 params_, 3139 params_,
3140 kDefaultPriority, 3140 DEFAULT_PRIORITY,
3141 callback3.callback(), 3141 callback3.callback(),
3142 pool_.get(), 3142 pool_.get(),
3143 BoundNetLog())); 3143 BoundNetLog()));
3144 3144
3145 EXPECT_TRUE(handle1.socket()->WasEverUsed()); 3145 EXPECT_TRUE(handle1.socket()->WasEverUsed());
3146 EXPECT_TRUE(handle2.socket()->WasEverUsed()); 3146 EXPECT_TRUE(handle2.socket()->WasEverUsed());
3147 EXPECT_FALSE(handle3.socket()->WasEverUsed()); 3147 EXPECT_FALSE(handle3.socket()->WasEverUsed());
3148 } 3148 }
3149 3149
3150 TEST_F(ClientSocketPoolBaseTest, RequestSockets) { 3150 TEST_F(ClientSocketPoolBaseTest, RequestSockets) {
3151 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 3151 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
3152 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 3152 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
3153 3153
3154 pool_->RequestSockets("a", &params_, 2, BoundNetLog()); 3154 pool_->RequestSockets("a", &params_, 2, BoundNetLog());
3155 3155
3156 ASSERT_TRUE(pool_->HasGroup("a")); 3156 ASSERT_TRUE(pool_->HasGroup("a"));
3157 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a")); 3157 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a"));
3158 EXPECT_EQ(2, pool_->NumUnassignedConnectJobsInGroup("a")); 3158 EXPECT_EQ(2, pool_->NumUnassignedConnectJobsInGroup("a"));
3159 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3159 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3160 3160
3161 ClientSocketHandle handle1; 3161 ClientSocketHandle handle1;
3162 TestCompletionCallback callback1; 3162 TestCompletionCallback callback1;
3163 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a", 3163 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a",
3164 params_, 3164 params_,
3165 kDefaultPriority, 3165 DEFAULT_PRIORITY,
3166 callback1.callback(), 3166 callback1.callback(),
3167 pool_.get(), 3167 pool_.get(),
3168 BoundNetLog())); 3168 BoundNetLog()));
3169 3169
3170 ClientSocketHandle handle2; 3170 ClientSocketHandle handle2;
3171 TestCompletionCallback callback2; 3171 TestCompletionCallback callback2;
3172 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("a", 3172 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("a",
3173 params_, 3173 params_,
3174 kDefaultPriority, 3174 DEFAULT_PRIORITY,
3175 callback2.callback(), 3175 callback2.callback(),
3176 pool_.get(), 3176 pool_.get(),
3177 BoundNetLog())); 3177 BoundNetLog()));
3178 3178
3179 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a")); 3179 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a"));
3180 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3180 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3181 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3181 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3182 3182
3183 EXPECT_EQ(OK, callback1.WaitForResult()); 3183 EXPECT_EQ(OK, callback1.WaitForResult());
3184 EXPECT_EQ(OK, callback2.WaitForResult()); 3184 EXPECT_EQ(OK, callback2.WaitForResult());
3185 handle1.Reset(); 3185 handle1.Reset();
3186 handle2.Reset(); 3186 handle2.Reset();
3187 3187
3188 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 3188 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
3189 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3189 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3190 EXPECT_EQ(2, pool_->IdleSocketCountInGroup("a")); 3190 EXPECT_EQ(2, pool_->IdleSocketCountInGroup("a"));
3191 } 3191 }
3192 3192
3193 TEST_F(ClientSocketPoolBaseTest, RequestSocketsWhenAlreadyHaveAConnectJob) { 3193 TEST_F(ClientSocketPoolBaseTest, RequestSocketsWhenAlreadyHaveAConnectJob) {
3194 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 3194 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
3195 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 3195 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
3196 3196
3197 ClientSocketHandle handle1; 3197 ClientSocketHandle handle1;
3198 TestCompletionCallback callback1; 3198 TestCompletionCallback callback1;
3199 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a", 3199 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a",
3200 params_, 3200 params_,
3201 kDefaultPriority, 3201 DEFAULT_PRIORITY,
3202 callback1.callback(), 3202 callback1.callback(),
3203 pool_.get(), 3203 pool_.get(),
3204 BoundNetLog())); 3204 BoundNetLog()));
3205 3205
3206 ASSERT_TRUE(pool_->HasGroup("a")); 3206 ASSERT_TRUE(pool_->HasGroup("a"));
3207 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 3207 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
3208 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3208 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3209 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3209 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3210 3210
3211 pool_->RequestSockets("a", &params_, 2, BoundNetLog()); 3211 pool_->RequestSockets("a", &params_, 2, BoundNetLog());
3212 3212
3213 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a")); 3213 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a"));
3214 EXPECT_EQ(1, pool_->NumUnassignedConnectJobsInGroup("a")); 3214 EXPECT_EQ(1, pool_->NumUnassignedConnectJobsInGroup("a"));
3215 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3215 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3216 3216
3217 ClientSocketHandle handle2; 3217 ClientSocketHandle handle2;
3218 TestCompletionCallback callback2; 3218 TestCompletionCallback callback2;
3219 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("a", 3219 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("a",
3220 params_, 3220 params_,
3221 kDefaultPriority, 3221 DEFAULT_PRIORITY,
3222 callback2.callback(), 3222 callback2.callback(),
3223 pool_.get(), 3223 pool_.get(),
3224 BoundNetLog())); 3224 BoundNetLog()));
3225 3225
3226 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a")); 3226 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a"));
3227 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3227 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3228 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3228 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3229 3229
3230 EXPECT_EQ(OK, callback1.WaitForResult()); 3230 EXPECT_EQ(OK, callback1.WaitForResult());
3231 EXPECT_EQ(OK, callback2.WaitForResult()); 3231 EXPECT_EQ(OK, callback2.WaitForResult());
3232 handle1.Reset(); 3232 handle1.Reset();
3233 handle2.Reset(); 3233 handle2.Reset();
3234 3234
3235 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 3235 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
3236 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3236 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3237 EXPECT_EQ(2, pool_->IdleSocketCountInGroup("a")); 3237 EXPECT_EQ(2, pool_->IdleSocketCountInGroup("a"));
3238 } 3238 }
3239 3239
3240 TEST_F(ClientSocketPoolBaseTest, 3240 TEST_F(ClientSocketPoolBaseTest,
3241 RequestSocketsWhenAlreadyHaveMultipleConnectJob) { 3241 RequestSocketsWhenAlreadyHaveMultipleConnectJob) {
3242 CreatePool(4, 4); 3242 CreatePool(4, 4);
3243 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 3243 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
3244 3244
3245 ClientSocketHandle handle1; 3245 ClientSocketHandle handle1;
3246 TestCompletionCallback callback1; 3246 TestCompletionCallback callback1;
3247 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a", 3247 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a",
3248 params_, 3248 params_,
3249 kDefaultPriority, 3249 DEFAULT_PRIORITY,
3250 callback1.callback(), 3250 callback1.callback(),
3251 pool_.get(), 3251 pool_.get(),
3252 BoundNetLog())); 3252 BoundNetLog()));
3253 3253
3254 ClientSocketHandle handle2; 3254 ClientSocketHandle handle2;
3255 TestCompletionCallback callback2; 3255 TestCompletionCallback callback2;
3256 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("a", 3256 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("a",
3257 params_, 3257 params_,
3258 kDefaultPriority, 3258 DEFAULT_PRIORITY,
3259 callback2.callback(), 3259 callback2.callback(),
3260 pool_.get(), 3260 pool_.get(),
3261 BoundNetLog())); 3261 BoundNetLog()));
3262 3262
3263 ClientSocketHandle handle3; 3263 ClientSocketHandle handle3;
3264 TestCompletionCallback callback3; 3264 TestCompletionCallback callback3;
3265 EXPECT_EQ(ERR_IO_PENDING, handle3.Init("a", 3265 EXPECT_EQ(ERR_IO_PENDING, handle3.Init("a",
3266 params_, 3266 params_,
3267 kDefaultPriority, 3267 DEFAULT_PRIORITY,
3268 callback3.callback(), 3268 callback3.callback(),
3269 pool_.get(), 3269 pool_.get(),
3270 BoundNetLog())); 3270 BoundNetLog()));
3271 3271
3272 ASSERT_TRUE(pool_->HasGroup("a")); 3272 ASSERT_TRUE(pool_->HasGroup("a"));
3273 EXPECT_EQ(3, pool_->NumConnectJobsInGroup("a")); 3273 EXPECT_EQ(3, pool_->NumConnectJobsInGroup("a"));
3274 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3274 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3275 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3275 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3276 3276
3277 pool_->RequestSockets("a", &params_, 2, BoundNetLog()); 3277 pool_->RequestSockets("a", &params_, 2, BoundNetLog());
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after
3339 } 3339 }
3340 3340
3341 TEST_F(ClientSocketPoolBaseTest, RequestSocketsCountIdleSockets) { 3341 TEST_F(ClientSocketPoolBaseTest, RequestSocketsCountIdleSockets) {
3342 CreatePool(4, 4); 3342 CreatePool(4, 4);
3343 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 3343 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
3344 3344
3345 ClientSocketHandle handle1; 3345 ClientSocketHandle handle1;
3346 TestCompletionCallback callback1; 3346 TestCompletionCallback callback1;
3347 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a", 3347 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a",
3348 params_, 3348 params_,
3349 kDefaultPriority, 3349 DEFAULT_PRIORITY,
3350 callback1.callback(), 3350 callback1.callback(),
3351 pool_.get(), 3351 pool_.get(),
3352 BoundNetLog())); 3352 BoundNetLog()));
3353 ASSERT_EQ(OK, callback1.WaitForResult()); 3353 ASSERT_EQ(OK, callback1.WaitForResult());
3354 handle1.Reset(); 3354 handle1.Reset();
3355 3355
3356 ASSERT_TRUE(pool_->HasGroup("a")); 3356 ASSERT_TRUE(pool_->HasGroup("a"));
3357 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 3357 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
3358 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3358 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3359 EXPECT_EQ(1, pool_->IdleSocketCountInGroup("a")); 3359 EXPECT_EQ(1, pool_->IdleSocketCountInGroup("a"));
3360 3360
3361 pool_->RequestSockets("a", &params_, 2, BoundNetLog()); 3361 pool_->RequestSockets("a", &params_, 2, BoundNetLog());
3362 3362
3363 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 3363 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
3364 EXPECT_EQ(1, pool_->NumUnassignedConnectJobsInGroup("a")); 3364 EXPECT_EQ(1, pool_->NumUnassignedConnectJobsInGroup("a"));
3365 EXPECT_EQ(1, pool_->IdleSocketCountInGroup("a")); 3365 EXPECT_EQ(1, pool_->IdleSocketCountInGroup("a"));
3366 } 3366 }
3367 3367
3368 TEST_F(ClientSocketPoolBaseTest, RequestSocketsCountActiveSockets) { 3368 TEST_F(ClientSocketPoolBaseTest, RequestSocketsCountActiveSockets) {
3369 CreatePool(4, 4); 3369 CreatePool(4, 4);
3370 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 3370 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
3371 3371
3372 ClientSocketHandle handle1; 3372 ClientSocketHandle handle1;
3373 TestCompletionCallback callback1; 3373 TestCompletionCallback callback1;
3374 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a", 3374 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a",
3375 params_, 3375 params_,
3376 kDefaultPriority, 3376 DEFAULT_PRIORITY,
3377 callback1.callback(), 3377 callback1.callback(),
3378 pool_.get(), 3378 pool_.get(),
3379 BoundNetLog())); 3379 BoundNetLog()));
3380 ASSERT_EQ(OK, callback1.WaitForResult()); 3380 ASSERT_EQ(OK, callback1.WaitForResult());
3381 3381
3382 ASSERT_TRUE(pool_->HasGroup("a")); 3382 ASSERT_TRUE(pool_->HasGroup("a"));
3383 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 3383 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
3384 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3384 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3385 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3385 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3386 EXPECT_EQ(1, pool_->NumActiveSocketsInGroup("a")); 3386 EXPECT_EQ(1, pool_->NumActiveSocketsInGroup("a"));
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
3443 3443
3444 pool_->RequestSockets("a", &params_, 2, BoundNetLog()); 3444 pool_->RequestSockets("a", &params_, 2, BoundNetLog());
3445 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a")); 3445 EXPECT_EQ(2, pool_->NumConnectJobsInGroup("a"));
3446 EXPECT_EQ(2, pool_->NumUnassignedConnectJobsInGroup("a")); 3446 EXPECT_EQ(2, pool_->NumUnassignedConnectJobsInGroup("a"));
3447 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3447 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3448 3448
3449 ClientSocketHandle handle1; 3449 ClientSocketHandle handle1;
3450 TestCompletionCallback callback1; 3450 TestCompletionCallback callback1;
3451 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a", 3451 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a",
3452 params_, 3452 params_,
3453 kDefaultPriority, 3453 DEFAULT_PRIORITY,
3454 callback1.callback(), 3454 callback1.callback(),
3455 pool_.get(), 3455 pool_.get(),
3456 BoundNetLog())); 3456 BoundNetLog()));
3457 ASSERT_EQ(OK, callback1.WaitForResult()); 3457 ASSERT_EQ(OK, callback1.WaitForResult());
3458 3458
3459 ClientSocketHandle handle2; 3459 ClientSocketHandle handle2;
3460 TestCompletionCallback callback2; 3460 TestCompletionCallback callback2;
3461 int rv = handle2.Init("a", 3461 int rv = handle2.Init("a",
3462 params_, 3462 params_,
3463 kDefaultPriority, 3463 DEFAULT_PRIORITY,
3464 callback2.callback(), 3464 callback2.callback(),
3465 pool_.get(), 3465 pool_.get(),
3466 BoundNetLog()); 3466 BoundNetLog());
3467 if (rv != OK) { 3467 if (rv != OK) {
3468 EXPECT_EQ(ERR_IO_PENDING, rv); 3468 EXPECT_EQ(ERR_IO_PENDING, rv);
3469 EXPECT_EQ(OK, callback2.WaitForResult()); 3469 EXPECT_EQ(OK, callback2.WaitForResult());
3470 } 3470 }
3471 3471
3472 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 3472 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
3473 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3473 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
3522 3522
3523 ASSERT_TRUE(pool_->HasGroup("a")); 3523 ASSERT_TRUE(pool_->HasGroup("a"));
3524 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 3524 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
3525 EXPECT_EQ(1, pool_->NumUnassignedConnectJobsInGroup("a")); 3525 EXPECT_EQ(1, pool_->NumUnassignedConnectJobsInGroup("a"));
3526 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3526 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3527 3527
3528 ClientSocketHandle handle1; 3528 ClientSocketHandle handle1;
3529 TestCompletionCallback callback1; 3529 TestCompletionCallback callback1;
3530 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a", 3530 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a",
3531 params_, 3531 params_,
3532 kDefaultPriority, 3532 DEFAULT_PRIORITY,
3533 callback1.callback(), 3533 callback1.callback(),
3534 pool_.get(), 3534 pool_.get(),
3535 BoundNetLog())); 3535 BoundNetLog()));
3536 3536
3537 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 3537 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
3538 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3538 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3539 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3539 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3540 3540
3541 ASSERT_EQ(OK, callback1.WaitForResult()); 3541 ASSERT_EQ(OK, callback1.WaitForResult());
3542 3542
(...skipping 14 matching lines...) Expand all
3557 3557
3558 ASSERT_TRUE(pool_->HasGroup("a")); 3558 ASSERT_TRUE(pool_->HasGroup("a"));
3559 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 3559 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
3560 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3560 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3561 EXPECT_EQ(1, pool_->IdleSocketCountInGroup("a")); 3561 EXPECT_EQ(1, pool_->IdleSocketCountInGroup("a"));
3562 3562
3563 ClientSocketHandle handle; 3563 ClientSocketHandle handle;
3564 TestCompletionCallback callback; 3564 TestCompletionCallback callback;
3565 EXPECT_EQ(OK, handle.Init("a", 3565 EXPECT_EQ(OK, handle.Init("a",
3566 params_, 3566 params_,
3567 kDefaultPriority, 3567 DEFAULT_PRIORITY,
3568 callback.callback(), 3568 callback.callback(),
3569 pool_.get(), 3569 pool_.get(),
3570 BoundNetLog())); 3570 BoundNetLog()));
3571 3571
3572 // Make sure the idle socket was used. 3572 // Make sure the idle socket was used.
3573 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3573 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3574 3574
3575 TestLoadTimingInfoConnectedReused(handle); 3575 TestLoadTimingInfoConnectedReused(handle);
3576 handle.Reset(); 3576 handle.Reset();
3577 TestLoadTimingInfoNotConnected(handle); 3577 TestLoadTimingInfoNotConnected(handle);
3578 } 3578 }
3579 3579
3580 // http://crbug.com/64940 regression test. 3580 // http://crbug.com/64940 regression test.
3581 TEST_F(ClientSocketPoolBaseTest, PreconnectClosesIdleSocketRemovesGroup) { 3581 TEST_F(ClientSocketPoolBaseTest, PreconnectClosesIdleSocketRemovesGroup) {
3582 const int kMaxTotalSockets = 3; 3582 const int kMaxTotalSockets = 3;
3583 const int kMaxSocketsPerGroup = 2; 3583 const int kMaxSocketsPerGroup = 2;
3584 CreatePool(kMaxTotalSockets, kMaxSocketsPerGroup); 3584 CreatePool(kMaxTotalSockets, kMaxSocketsPerGroup);
3585 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 3585 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
3586 3586
3587 // Note that group name ordering matters here. "a" comes before "b", so 3587 // Note that group name ordering matters here. "a" comes before "b", so
3588 // CloseOneIdleSocket() will try to close "a"'s idle socket. 3588 // CloseOneIdleSocket() will try to close "a"'s idle socket.
3589 3589
3590 // Set up one idle socket in "a". 3590 // Set up one idle socket in "a".
3591 ClientSocketHandle handle1; 3591 ClientSocketHandle handle1;
3592 TestCompletionCallback callback1; 3592 TestCompletionCallback callback1;
3593 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a", 3593 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("a",
3594 params_, 3594 params_,
3595 kDefaultPriority, 3595 DEFAULT_PRIORITY,
3596 callback1.callback(), 3596 callback1.callback(),
3597 pool_.get(), 3597 pool_.get(),
3598 BoundNetLog())); 3598 BoundNetLog()));
3599 3599
3600 ASSERT_EQ(OK, callback1.WaitForResult()); 3600 ASSERT_EQ(OK, callback1.WaitForResult());
3601 handle1.Reset(); 3601 handle1.Reset();
3602 EXPECT_EQ(1, pool_->IdleSocketCountInGroup("a")); 3602 EXPECT_EQ(1, pool_->IdleSocketCountInGroup("a"));
3603 3603
3604 // Set up two active sockets in "b". 3604 // Set up two active sockets in "b".
3605 ClientSocketHandle handle2; 3605 ClientSocketHandle handle2;
3606 TestCompletionCallback callback2; 3606 TestCompletionCallback callback2;
3607 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("b", 3607 EXPECT_EQ(ERR_IO_PENDING, handle1.Init("b",
3608 params_, 3608 params_,
3609 kDefaultPriority, 3609 DEFAULT_PRIORITY,
3610 callback1.callback(), 3610 callback1.callback(),
3611 pool_.get(), 3611 pool_.get(),
3612 BoundNetLog())); 3612 BoundNetLog()));
3613 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("b", 3613 EXPECT_EQ(ERR_IO_PENDING, handle2.Init("b",
3614 params_, 3614 params_,
3615 kDefaultPriority, 3615 DEFAULT_PRIORITY,
3616 callback2.callback(), 3616 callback2.callback(),
3617 pool_.get(), 3617 pool_.get(),
3618 BoundNetLog())); 3618 BoundNetLog()));
3619 3619
3620 ASSERT_EQ(OK, callback1.WaitForResult()); 3620 ASSERT_EQ(OK, callback1.WaitForResult());
3621 ASSERT_EQ(OK, callback2.WaitForResult()); 3621 ASSERT_EQ(OK, callback2.WaitForResult());
3622 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("b")); 3622 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("b"));
3623 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("b")); 3623 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("b"));
3624 EXPECT_EQ(2, pool_->NumActiveSocketsInGroup("b")); 3624 EXPECT_EQ(2, pool_->NumActiveSocketsInGroup("b"));
3625 3625
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after
3693 EXPECT_EQ(1, pool_->NumUnassignedConnectJobsInGroup("a")); 3693 EXPECT_EQ(1, pool_->NumUnassignedConnectJobsInGroup("a"));
3694 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3694 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3695 base::MessageLoop::current()->RunUntilIdle(); 3695 base::MessageLoop::current()->RunUntilIdle();
3696 3696
3697 // Make the backup job be a pending job, so it completes normally. 3697 // Make the backup job be a pending job, so it completes normally.
3698 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 3698 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
3699 ClientSocketHandle handle; 3699 ClientSocketHandle handle;
3700 TestCompletionCallback callback; 3700 TestCompletionCallback callback;
3701 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 3701 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
3702 params_, 3702 params_,
3703 kDefaultPriority, 3703 DEFAULT_PRIORITY,
3704 callback.callback(), 3704 callback.callback(),
3705 pool_.get(), 3705 pool_.get(),
3706 BoundNetLog())); 3706 BoundNetLog()));
3707 // Timer has started, but the backup connect job shouldn't be created yet. 3707 // Timer has started, but the backup connect job shouldn't be created yet.
3708 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 3708 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
3709 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3709 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3710 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3710 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3711 EXPECT_EQ(0, pool_->NumActiveSocketsInGroup("a")); 3711 EXPECT_EQ(0, pool_->NumActiveSocketsInGroup("a"));
3712 ASSERT_EQ(OK, callback.WaitForResult()); 3712 ASSERT_EQ(OK, callback.WaitForResult());
3713 3713
3714 // The hung connect job should still be there, but everything else should be 3714 // The hung connect job should still be there, but everything else should be
3715 // complete. 3715 // complete.
3716 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a")); 3716 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
3717 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a")); 3717 EXPECT_EQ(0, pool_->NumUnassignedConnectJobsInGroup("a"));
3718 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a")); 3718 EXPECT_EQ(0, pool_->IdleSocketCountInGroup("a"));
3719 EXPECT_EQ(1, pool_->NumActiveSocketsInGroup("a")); 3719 EXPECT_EQ(1, pool_->NumActiveSocketsInGroup("a"));
3720 } 3720 }
3721 3721
3722 class MockLayeredPool : public HigherLayeredPool { 3722 class MockLayeredPool : public HigherLayeredPool {
3723 public: 3723 public:
3724 MockLayeredPool(TestClientSocketPool* pool, 3724 MockLayeredPool(TestClientSocketPool* pool,
3725 const std::string& group_name) 3725 const std::string& group_name)
3726 : pool_(pool), 3726 : pool_(pool),
3727 params_(new TestSocketParams),
3728 group_name_(group_name), 3727 group_name_(group_name),
3729 can_release_connection_(true) { 3728 can_release_connection_(true) {
3730 pool_->AddHigherLayeredPool(this); 3729 pool_->AddHigherLayeredPool(this);
3731 } 3730 }
3732 3731
3733 ~MockLayeredPool() { 3732 ~MockLayeredPool() {
3734 pool_->RemoveHigherLayeredPool(this); 3733 pool_->RemoveHigherLayeredPool(this);
3735 } 3734 }
3736 3735
3737 int RequestSocket(TestClientSocketPool* pool) { 3736 int RequestSocket(TestClientSocketPool* pool) {
3738 return handle_.Init(group_name_, params_, kDefaultPriority, 3737 return handle_.Init(group_name_, new TestSocketParams(RESPECT_LIMITS),
3738 DEFAULT_PRIORITY,
3739 callback_.callback(), pool, BoundNetLog()); 3739 callback_.callback(), pool, BoundNetLog());
3740 } 3740 }
3741 3741
3742 int RequestSocketWithoutLimits(TestClientSocketPool* pool) { 3742 int RequestSocketWithoutLimits(TestClientSocketPool* pool) {
3743 params_->set_ignore_limits(true); 3743 return handle_.Init(group_name_, new TestSocketParams(IGNORE_LIMITS),
3744 return handle_.Init(group_name_, params_, kDefaultPriority, 3744 MAXIMUM_PRIORITY,
3745 callback_.callback(), pool, BoundNetLog()); 3745 callback_.callback(), pool, BoundNetLog());
3746 } 3746 }
3747 3747
3748 bool ReleaseOneConnection() { 3748 bool ReleaseOneConnection() {
3749 if (!handle_.is_initialized() || !can_release_connection_) { 3749 if (!handle_.is_initialized() || !can_release_connection_) {
3750 return false; 3750 return false;
3751 } 3751 }
3752 handle_.socket()->Disconnect(); 3752 handle_.socket()->Disconnect();
3753 handle_.Reset(); 3753 handle_.Reset();
3754 return true; 3754 return true;
3755 } 3755 }
3756 3756
3757 void set_can_release_connection(bool can_release_connection) { 3757 void set_can_release_connection(bool can_release_connection) {
3758 can_release_connection_ = can_release_connection; 3758 can_release_connection_ = can_release_connection;
3759 } 3759 }
3760 3760
3761 MOCK_METHOD0(CloseOneIdleConnection, bool()); 3761 MOCK_METHOD0(CloseOneIdleConnection, bool());
3762 3762
3763 private: 3763 private:
3764 TestClientSocketPool* const pool_; 3764 TestClientSocketPool* const pool_;
3765 scoped_refptr<TestSocketParams> params_;
3766 ClientSocketHandle handle_; 3765 ClientSocketHandle handle_;
3767 TestCompletionCallback callback_; 3766 TestCompletionCallback callback_;
3768 const std::string group_name_; 3767 const std::string group_name_;
3769 bool can_release_connection_; 3768 bool can_release_connection_;
3770 }; 3769 };
3771 3770
3772 TEST_F(ClientSocketPoolBaseTest, FailToCloseIdleSocketsNotHeldByLayeredPool) { 3771 TEST_F(ClientSocketPoolBaseTest, FailToCloseIdleSocketsNotHeldByLayeredPool) {
3773 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup); 3772 CreatePool(kDefaultMaxSockets, kDefaultMaxSocketsPerGroup);
3774 connect_job_factory_->set_job_type(TestConnectJob::kMockJob); 3773 connect_job_factory_->set_job_type(TestConnectJob::kMockJob);
3775 3774
(...skipping 24 matching lines...) Expand all
3800 3799
3801 MockLayeredPool mock_layered_pool(pool_.get(), "foo"); 3800 MockLayeredPool mock_layered_pool(pool_.get(), "foo");
3802 EXPECT_EQ(OK, mock_layered_pool.RequestSocket(pool_.get())); 3801 EXPECT_EQ(OK, mock_layered_pool.RequestSocket(pool_.get()));
3803 EXPECT_CALL(mock_layered_pool, CloseOneIdleConnection()) 3802 EXPECT_CALL(mock_layered_pool, CloseOneIdleConnection())
3804 .WillOnce(Invoke(&mock_layered_pool, 3803 .WillOnce(Invoke(&mock_layered_pool,
3805 &MockLayeredPool::ReleaseOneConnection)); 3804 &MockLayeredPool::ReleaseOneConnection));
3806 ClientSocketHandle handle; 3805 ClientSocketHandle handle;
3807 TestCompletionCallback callback; 3806 TestCompletionCallback callback;
3808 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 3807 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
3809 params_, 3808 params_,
3810 kDefaultPriority, 3809 DEFAULT_PRIORITY,
3811 callback.callback(), 3810 callback.callback(),
3812 pool_.get(), 3811 pool_.get(),
3813 BoundNetLog())); 3812 BoundNetLog()));
3814 EXPECT_EQ(OK, callback.WaitForResult()); 3813 EXPECT_EQ(OK, callback.WaitForResult());
3815 } 3814 }
3816 3815
3817 // Same as above, but the idle socket is in the same group as the stalled 3816 // Same as above, but the idle socket is in the same group as the stalled
3818 // socket, and closes the only other request in its group when closing requests 3817 // socket, and closes the only other request in its group when closing requests
3819 // in higher layered pools. This generally shouldn't happen, but it may be 3818 // in higher layered pools. This generally shouldn't happen, but it may be
3820 // possible if a higher level pool issues a request and the request is 3819 // possible if a higher level pool issues a request and the request is
3821 // subsequently cancelled. Even if it's not possible, best not to crash. 3820 // subsequently cancelled. Even if it's not possible, best not to crash.
3822 TEST_F(ClientSocketPoolBaseTest, 3821 TEST_F(ClientSocketPoolBaseTest,
3823 CloseIdleSocketsHeldByLayeredPoolWhenNeededSameGroup) { 3822 CloseIdleSocketsHeldByLayeredPoolWhenNeededSameGroup) {
3824 CreatePool(2, 2); 3823 CreatePool(2, 2);
3825 connect_job_factory_->set_job_type(TestConnectJob::kMockJob); 3824 connect_job_factory_->set_job_type(TestConnectJob::kMockJob);
3826 3825
3827 // Need a socket in another group for the pool to be stalled (If a group 3826 // Need a socket in another group for the pool to be stalled (If a group
3828 // has the maximum number of connections already, it's not stalled). 3827 // has the maximum number of connections already, it's not stalled).
3829 ClientSocketHandle handle1; 3828 ClientSocketHandle handle1;
3830 TestCompletionCallback callback1; 3829 TestCompletionCallback callback1;
3831 EXPECT_EQ(OK, handle1.Init("group1", 3830 EXPECT_EQ(OK, handle1.Init("group1",
3832 params_, 3831 params_,
3833 kDefaultPriority, 3832 DEFAULT_PRIORITY,
3834 callback1.callback(), 3833 callback1.callback(),
3835 pool_.get(), 3834 pool_.get(),
3836 BoundNetLog())); 3835 BoundNetLog()));
3837 3836
3838 MockLayeredPool mock_layered_pool(pool_.get(), "group2"); 3837 MockLayeredPool mock_layered_pool(pool_.get(), "group2");
3839 EXPECT_EQ(OK, mock_layered_pool.RequestSocket(pool_.get())); 3838 EXPECT_EQ(OK, mock_layered_pool.RequestSocket(pool_.get()));
3840 EXPECT_CALL(mock_layered_pool, CloseOneIdleConnection()) 3839 EXPECT_CALL(mock_layered_pool, CloseOneIdleConnection())
3841 .WillOnce(Invoke(&mock_layered_pool, 3840 .WillOnce(Invoke(&mock_layered_pool,
3842 &MockLayeredPool::ReleaseOneConnection)); 3841 &MockLayeredPool::ReleaseOneConnection));
3843 ClientSocketHandle handle; 3842 ClientSocketHandle handle;
3844 TestCompletionCallback callback2; 3843 TestCompletionCallback callback2;
3845 EXPECT_EQ(ERR_IO_PENDING, handle.Init("group2", 3844 EXPECT_EQ(ERR_IO_PENDING, handle.Init("group2",
3846 params_, 3845 params_,
3847 kDefaultPriority, 3846 DEFAULT_PRIORITY,
3848 callback2.callback(), 3847 callback2.callback(),
3849 pool_.get(), 3848 pool_.get(),
3850 BoundNetLog())); 3849 BoundNetLog()));
3851 EXPECT_EQ(OK, callback2.WaitForResult()); 3850 EXPECT_EQ(OK, callback2.WaitForResult());
3852 } 3851 }
3853 3852
3854 // Tests the case when an idle socket can be closed when a new request is 3853 // Tests the case when an idle socket can be closed when a new request is
3855 // issued, and the new request belongs to a group that was previously stalled. 3854 // issued, and the new request belongs to a group that was previously stalled.
3856 TEST_F(ClientSocketPoolBaseTest, 3855 TEST_F(ClientSocketPoolBaseTest,
3857 CloseIdleSocketsHeldByLayeredPoolInSameGroupWhenNeeded) { 3856 CloseIdleSocketsHeldByLayeredPoolInSameGroupWhenNeeded) {
3858 CreatePool(2, 2); 3857 CreatePool(2, 2);
3859 std::list<TestConnectJob::JobType> job_types; 3858 std::list<TestConnectJob::JobType> job_types;
3860 job_types.push_back(TestConnectJob::kMockJob); 3859 job_types.push_back(TestConnectJob::kMockJob);
3861 job_types.push_back(TestConnectJob::kMockJob); 3860 job_types.push_back(TestConnectJob::kMockJob);
3862 job_types.push_back(TestConnectJob::kMockJob); 3861 job_types.push_back(TestConnectJob::kMockJob);
3863 job_types.push_back(TestConnectJob::kMockJob); 3862 job_types.push_back(TestConnectJob::kMockJob);
3864 connect_job_factory_->set_job_types(&job_types); 3863 connect_job_factory_->set_job_types(&job_types);
3865 3864
3866 ClientSocketHandle handle1; 3865 ClientSocketHandle handle1;
3867 TestCompletionCallback callback1; 3866 TestCompletionCallback callback1;
3868 EXPECT_EQ(OK, handle1.Init("group1", 3867 EXPECT_EQ(OK, handle1.Init("group1",
3869 params_, 3868 params_,
3870 kDefaultPriority, 3869 DEFAULT_PRIORITY,
3871 callback1.callback(), 3870 callback1.callback(),
3872 pool_.get(), 3871 pool_.get(),
3873 BoundNetLog())); 3872 BoundNetLog()));
3874 3873
3875 MockLayeredPool mock_layered_pool(pool_.get(), "group2"); 3874 MockLayeredPool mock_layered_pool(pool_.get(), "group2");
3876 EXPECT_EQ(OK, mock_layered_pool.RequestSocket(pool_.get())); 3875 EXPECT_EQ(OK, mock_layered_pool.RequestSocket(pool_.get()));
3877 EXPECT_CALL(mock_layered_pool, CloseOneIdleConnection()) 3876 EXPECT_CALL(mock_layered_pool, CloseOneIdleConnection())
3878 .WillRepeatedly(Invoke(&mock_layered_pool, 3877 .WillRepeatedly(Invoke(&mock_layered_pool,
3879 &MockLayeredPool::ReleaseOneConnection)); 3878 &MockLayeredPool::ReleaseOneConnection));
3880 mock_layered_pool.set_can_release_connection(false); 3879 mock_layered_pool.set_can_release_connection(false);
3881 3880
3882 // The third request is made when the socket pool is in a stalled state. 3881 // The third request is made when the socket pool is in a stalled state.
3883 ClientSocketHandle handle3; 3882 ClientSocketHandle handle3;
3884 TestCompletionCallback callback3; 3883 TestCompletionCallback callback3;
3885 EXPECT_EQ(ERR_IO_PENDING, handle3.Init("group3", 3884 EXPECT_EQ(ERR_IO_PENDING, handle3.Init("group3",
3886 params_, 3885 params_,
3887 kDefaultPriority, 3886 DEFAULT_PRIORITY,
3888 callback3.callback(), 3887 callback3.callback(),
3889 pool_.get(), 3888 pool_.get(),
3890 BoundNetLog())); 3889 BoundNetLog()));
3891 3890
3892 base::RunLoop().RunUntilIdle(); 3891 base::RunLoop().RunUntilIdle();
3893 EXPECT_FALSE(callback3.have_result()); 3892 EXPECT_FALSE(callback3.have_result());
3894 3893
3895 // The fourth request is made when the pool is no longer stalled. The third 3894 // The fourth request is made when the pool is no longer stalled. The third
3896 // request should be serviced first, since it was issued first and has the 3895 // request should be serviced first, since it was issued first and has the
3897 // same priority. 3896 // same priority.
3898 mock_layered_pool.set_can_release_connection(true); 3897 mock_layered_pool.set_can_release_connection(true);
3899 ClientSocketHandle handle4; 3898 ClientSocketHandle handle4;
3900 TestCompletionCallback callback4; 3899 TestCompletionCallback callback4;
3901 EXPECT_EQ(ERR_IO_PENDING, handle4.Init("group3", 3900 EXPECT_EQ(ERR_IO_PENDING, handle4.Init("group3",
3902 params_, 3901 params_,
3903 kDefaultPriority, 3902 DEFAULT_PRIORITY,
3904 callback4.callback(), 3903 callback4.callback(),
3905 pool_.get(), 3904 pool_.get(),
3906 BoundNetLog())); 3905 BoundNetLog()));
3907 EXPECT_EQ(OK, callback3.WaitForResult()); 3906 EXPECT_EQ(OK, callback3.WaitForResult());
3908 EXPECT_FALSE(callback4.have_result()); 3907 EXPECT_FALSE(callback4.have_result());
3909 3908
3910 // Closing a handle should free up another socket slot. 3909 // Closing a handle should free up another socket slot.
3911 handle1.Reset(); 3910 handle1.Reset();
3912 EXPECT_EQ(OK, callback4.WaitForResult()); 3911 EXPECT_EQ(OK, callback4.WaitForResult());
3913 } 3912 }
(...skipping 11 matching lines...) Expand all
3925 job_types.push_back(TestConnectJob::kMockJob); 3924 job_types.push_back(TestConnectJob::kMockJob);
3926 job_types.push_back(TestConnectJob::kMockJob); 3925 job_types.push_back(TestConnectJob::kMockJob);
3927 job_types.push_back(TestConnectJob::kMockJob); 3926 job_types.push_back(TestConnectJob::kMockJob);
3928 job_types.push_back(TestConnectJob::kMockJob); 3927 job_types.push_back(TestConnectJob::kMockJob);
3929 connect_job_factory_->set_job_types(&job_types); 3928 connect_job_factory_->set_job_types(&job_types);
3930 3929
3931 ClientSocketHandle handle1; 3930 ClientSocketHandle handle1;
3932 TestCompletionCallback callback1; 3931 TestCompletionCallback callback1;
3933 EXPECT_EQ(OK, handle1.Init("group1", 3932 EXPECT_EQ(OK, handle1.Init("group1",
3934 params_, 3933 params_,
3935 kDefaultPriority, 3934 DEFAULT_PRIORITY,
3936 callback1.callback(), 3935 callback1.callback(),
3937 pool_.get(), 3936 pool_.get(),
3938 BoundNetLog())); 3937 BoundNetLog()));
3939 3938
3940 MockLayeredPool mock_layered_pool(pool_.get(), "group2"); 3939 MockLayeredPool mock_layered_pool(pool_.get(), "group2");
3941 EXPECT_EQ(OK, mock_layered_pool.RequestSocket(pool_.get())); 3940 EXPECT_EQ(OK, mock_layered_pool.RequestSocket(pool_.get()));
3942 EXPECT_CALL(mock_layered_pool, CloseOneIdleConnection()) 3941 EXPECT_CALL(mock_layered_pool, CloseOneIdleConnection())
3943 .WillRepeatedly(Invoke(&mock_layered_pool, 3942 .WillRepeatedly(Invoke(&mock_layered_pool,
3944 &MockLayeredPool::ReleaseOneConnection)); 3943 &MockLayeredPool::ReleaseOneConnection));
3945 mock_layered_pool.set_can_release_connection(false); 3944 mock_layered_pool.set_can_release_connection(false);
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
3988 &MockLayeredPool::ReleaseOneConnection)); 3987 &MockLayeredPool::ReleaseOneConnection));
3989 MockLayeredPool mock_layered_pool2(pool_.get(), "bar"); 3988 MockLayeredPool mock_layered_pool2(pool_.get(), "bar");
3990 EXPECT_EQ(OK, mock_layered_pool2.RequestSocketWithoutLimits(pool_.get())); 3989 EXPECT_EQ(OK, mock_layered_pool2.RequestSocketWithoutLimits(pool_.get()));
3991 EXPECT_CALL(mock_layered_pool2, CloseOneIdleConnection()) 3990 EXPECT_CALL(mock_layered_pool2, CloseOneIdleConnection())
3992 .WillRepeatedly(Invoke(&mock_layered_pool2, 3991 .WillRepeatedly(Invoke(&mock_layered_pool2,
3993 &MockLayeredPool::ReleaseOneConnection)); 3992 &MockLayeredPool::ReleaseOneConnection));
3994 ClientSocketHandle handle; 3993 ClientSocketHandle handle;
3995 TestCompletionCallback callback; 3994 TestCompletionCallback callback;
3996 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a", 3995 EXPECT_EQ(ERR_IO_PENDING, handle.Init("a",
3997 params_, 3996 params_,
3998 kDefaultPriority, 3997 DEFAULT_PRIORITY,
3999 callback.callback(), 3998 callback.callback(),
4000 pool_.get(), 3999 pool_.get(),
4001 BoundNetLog())); 4000 BoundNetLog()));
4002 EXPECT_EQ(OK, callback.WaitForResult()); 4001 EXPECT_EQ(OK, callback.WaitForResult());
4003 } 4002 }
4004 4003
4005 // Test that when a socket pool and group are at their limits, a request 4004 // Test that when a socket pool and group are at their limits, a request
4006 // with |ignore_limits| triggers creation of a new socket, and gets the socket 4005 // with |ignore_limits| triggers creation of a new socket, and gets the socket
4007 // instead of a request with the same priority that was issued earlier, but 4006 // instead of a request with the same priority that was issued earlier, but
4008 // that does not have |ignore_limits| set. 4007 // that does not have |ignore_limits| set.
4009 TEST_F(ClientSocketPoolBaseTest, IgnoreLimits) { 4008 TEST_F(ClientSocketPoolBaseTest, IgnoreLimits) {
4010 scoped_refptr<TestSocketParams> params_ignore_limits(new TestSocketParams()); 4009 scoped_refptr<TestSocketParams> params_ignore_limits(
4011 params_ignore_limits->set_ignore_limits(true); 4010 new TestSocketParams(IGNORE_LIMITS));
4012 CreatePool(1, 1); 4011 CreatePool(1, 1);
4013 4012
4014 // Issue a request to reach the socket pool limit. 4013 // Issue a request to reach the socket pool limit.
4015 EXPECT_EQ(OK, StartRequestWithParams("a", kDefaultPriority, params_)); 4014 EXPECT_EQ(OK, StartRequestWithParams("a", DEFAULT_PRIORITY, params_));
4016 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 4015 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
4017 4016
4018 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 4017 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
4019 4018
4020 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", kDefaultPriority, 4019 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", DEFAULT_PRIORITY,
4021 params_)); 4020 params_));
4022 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 4021 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
4023 4022
4024 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", kDefaultPriority, 4023 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", MAXIMUM_PRIORITY,
4025 params_ignore_limits)); 4024 params_ignore_limits));
4026 ASSERT_EQ(1, pool_->NumConnectJobsInGroup("a")); 4025 ASSERT_EQ(1, pool_->NumConnectJobsInGroup("a"));
4027 4026
4028 EXPECT_EQ(OK, request(2)->WaitForResult());
4029 EXPECT_FALSE(request(1)->have_result());
4030 }
4031
4032 // Test that when a socket pool and group are at their limits, a request with
4033 // |ignore_limits| set triggers creation of a new socket, and gets the socket
4034 // instead of a request with a higher priority that was issued earlier, but
4035 // that does not have |ignore_limits| set.
4036 TEST_F(ClientSocketPoolBaseTest, IgnoreLimitsLowPriority) {
4037 scoped_refptr<TestSocketParams> params_ignore_limits(new TestSocketParams());
4038 params_ignore_limits->set_ignore_limits(true);
4039 CreatePool(1, 1);
4040
4041 // Issue a request to reach the socket pool limit.
4042 EXPECT_EQ(OK, StartRequestWithParams("a", HIGHEST, params_));
4043 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
4044
4045 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
4046
4047 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", HIGHEST, params_));
4048 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
4049
4050 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", LOW,
4051 params_ignore_limits));
4052 ASSERT_EQ(1, pool_->NumConnectJobsInGroup("a"));
4053
4054 EXPECT_EQ(OK, request(2)->WaitForResult()); 4027 EXPECT_EQ(OK, request(2)->WaitForResult());
4055 EXPECT_FALSE(request(1)->have_result()); 4028 EXPECT_FALSE(request(1)->have_result());
4056 } 4029 }
4057 4030
4058 // Test that when a socket pool and group are at their limits, a request with
4059 // |ignore_limits| set triggers creation of a new socket, and gets the socket
4060 // instead of a request with a higher priority that was issued later and
4061 // does not have |ignore_limits| set.
4062 TEST_F(ClientSocketPoolBaseTest, IgnoreLimitsLowPriority2) {
4063 scoped_refptr<TestSocketParams> params_ignore_limits(new TestSocketParams());
4064 params_ignore_limits->set_ignore_limits(true);
4065 CreatePool(1, 1);
4066
4067 // Issue a request to reach the socket pool limit.
4068 EXPECT_EQ(OK, StartRequestWithParams("a", HIGHEST, params_));
4069 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
4070
4071 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
4072
4073 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", LOW,
4074 params_ignore_limits));
4075 ASSERT_EQ(1, pool_->NumConnectJobsInGroup("a"));
4076
4077 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", HIGHEST, params_));
4078 EXPECT_EQ(1, pool_->NumConnectJobsInGroup("a"));
4079
4080 EXPECT_EQ(OK, request(1)->WaitForResult());
4081 EXPECT_FALSE(request(2)->have_result());
4082 }
4083
4084 // Test that when a socket pool and group are at their limits, a ConnectJob 4031 // Test that when a socket pool and group are at their limits, a ConnectJob
4085 // issued for a request with |ignore_limits| set is not cancelled when a request 4032 // issued for a request with |ignore_limits| set is not cancelled when a request
4086 // without |ignore_limits| issued to the same group is cancelled. 4033 // without |ignore_limits| issued to the same group is cancelled.
4087 TEST_F(ClientSocketPoolBaseTest, IgnoreLimitsCancelOtherJob) { 4034 TEST_F(ClientSocketPoolBaseTest, IgnoreLimitsCancelOtherJob) {
4088 scoped_refptr<TestSocketParams> params_ignore_limits(new TestSocketParams()); 4035 scoped_refptr<TestSocketParams> params_ignore_limits(
4089 params_ignore_limits->set_ignore_limits(true); 4036 new TestSocketParams(IGNORE_LIMITS));
4090 CreatePool(1, 1); 4037 CreatePool(1, 1);
4091 4038
4092 // Issue a request to reach the socket pool limit. 4039 // Issue a request to reach the socket pool limit.
4093 EXPECT_EQ(OK, StartRequestWithParams("a", HIGHEST, params_)); 4040 EXPECT_EQ(OK, StartRequestWithParams("a", HIGHEST, params_));
4094 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 4041 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
4095 4042
4096 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob); 4043 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
4097 4044
4098 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", HIGHEST, params_)); 4045 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", HIGHEST, params_));
mmenke 2013/10/30 15:54:59 These should be MAXIMUM_PRIORITY now.
akalin 2013/10/30 23:32:16 Done.
4099 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a")); 4046 EXPECT_EQ(0, pool_->NumConnectJobsInGroup("a"));
4100 4047
4101 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", HIGHEST, 4048 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", MAXIMUM_PRIORITY,
4102 params_ignore_limits)); 4049 params_ignore_limits));
4103 ASSERT_EQ(1, pool_->NumConnectJobsInGroup("a")); 4050 ASSERT_EQ(1, pool_->NumConnectJobsInGroup("a"));
4104 4051
4105 // Cancel the pending request without ignore_limits set. The ConnectJob 4052 // Cancel the pending request without ignore_limits set. The ConnectJob
4106 // should not be cancelled. 4053 // should not be cancelled.
4107 request(1)->handle()->Reset(); 4054 request(1)->handle()->Reset();
4108 ASSERT_EQ(1, pool_->NumConnectJobsInGroup("a")); 4055 ASSERT_EQ(1, pool_->NumConnectJobsInGroup("a"));
4109 4056
4110 EXPECT_EQ(OK, request(2)->WaitForResult()); 4057 EXPECT_EQ(OK, request(2)->WaitForResult());
mmenke 2013/10/30 15:54:59 WAit...Why is this passing? I don't see where we
akalin 2013/10/30 23:32:16 Did you m ean the previous test (IgnoreLimits)? I'
mmenke 2013/10/31 15:37:26 Ah! I missed the cancel. Yea, I was thinking thi
4111 EXPECT_FALSE(request(1)->have_result()); 4058 EXPECT_FALSE(request(1)->have_result());
4112 } 4059 }
4113 4060
4114 // More involved test of ignore limits. Issues a bunch of requests and later
4115 // checks the order in which they receive sockets.
4116 TEST_F(ClientSocketPoolBaseTest, IgnoreLimitsOrder) {
4117 scoped_refptr<TestSocketParams> params_ignore_limits(new TestSocketParams());
4118 params_ignore_limits->set_ignore_limits(true);
4119 CreatePool(1, 1);
4120
4121 connect_job_factory_->set_job_type(TestConnectJob::kMockPendingJob);
4122
4123 // Requests 0 and 1 do not have ignore_limits set, so they finish last. Since
4124 // the maximum number of sockets per pool is 1, the second requests does not
4125 // trigger a ConnectJob.
4126 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", HIGHEST, params_));
4127 EXPECT_EQ(ERR_IO_PENDING, StartRequestWithParams("a", HIGHEST, params_));
4128
4129 // Requests 2 and 3 have ignore_limits set, but have a low priority, so they
4130 // finish just before the first two.
4131 EXPECT_EQ(ERR_IO_PENDING,
4132 StartRequestWithParams("a", LOW, params_ignore_limits));
4133 EXPECT_EQ(ERR_IO_PENDING,
4134 StartRequestWithParams("a", LOW, params_ignore_limits));
4135
4136 // Request 4 finishes first, since it is high priority and ignores limits.
4137 EXPECT_EQ(ERR_IO_PENDING,
4138 StartRequestWithParams("a", HIGHEST, params_ignore_limits));
4139
4140 // Request 5 and 6 are cancelled right after starting. This should result in
4141 // creating two ConnectJobs. Since only one request (Request 1) did not
4142 // result in creating a ConnectJob, only one of the ConnectJobs should be
4143 // cancelled when the requests are.
4144 EXPECT_EQ(ERR_IO_PENDING,
4145 StartRequestWithParams("a", HIGHEST, params_ignore_limits));
4146 EXPECT_EQ(ERR_IO_PENDING,
4147 StartRequestWithParams("a", HIGHEST, params_ignore_limits));
4148 EXPECT_EQ(6, pool_->NumConnectJobsInGroup("a"));
4149 request(5)->handle()->Reset();
4150 EXPECT_EQ(6, pool_->NumConnectJobsInGroup("a"));
4151 request(6)->handle()->Reset();
4152 ASSERT_EQ(5, pool_->NumConnectJobsInGroup("a"));
4153
4154 // Wait for the last request to get a socket.
4155 EXPECT_EQ(OK, request(1)->WaitForResult());
4156
4157 // Check order in which requests received sockets.
4158 // These are 1-based indices, while request(x) uses 0-based indices.
4159 EXPECT_EQ(1, GetOrderOfRequest(5));
4160 EXPECT_EQ(2, GetOrderOfRequest(3));
4161 EXPECT_EQ(3, GetOrderOfRequest(4));
4162 EXPECT_EQ(4, GetOrderOfRequest(1));
4163 EXPECT_EQ(5, GetOrderOfRequest(2));
4164 }
4165
4166 } // namespace 4061 } // namespace
4167 4062
4168 } // namespace net 4063 } // namespace net
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698