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

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

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

Powered by Google App Engine
This is Rietveld 408576698