OLD | NEW |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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", ¶ms_, 2, BoundNetLog()); | 3154 pool_->RequestSockets("a", ¶ms_, 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", ¶ms_, 2, BoundNetLog()); | 3211 pool_->RequestSockets("a", ¶ms_, 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", ¶ms_, 2, BoundNetLog()); | 3277 pool_->RequestSockets("a", ¶ms_, 2, BoundNetLog()); |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
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", ¶ms_, 2, BoundNetLog()); | 3361 pool_->RequestSockets("a", ¶ms_, 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 Loading... |
3442 | 3443 |
3443 pool_->RequestSockets("a", ¶ms_, 2, BoundNetLog()); | 3444 pool_->RequestSockets("a", ¶ms_, 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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 |
OLD | NEW |