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