[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 1 | // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
[email protected] | 97e6c4c | 2011-05-18 16:08:51 | [diff] [blame] | 5 | #include "content/browser/resolve_proxy_msg_helper.h" |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 6 | |
[email protected] | 9214555 | 2011-10-31 16:28:03 | [diff] [blame] | 7 | #include "content/browser/browser_thread_impl.h" |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 8 | #include "content/common/view_messages.h" |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 9 | #include "ipc/ipc_test_sink.h" |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 10 | #include "net/base/net_errors.h" |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 11 | #include "net/proxy/mock_proxy_resolver.h" |
[email protected] | e9e6b1c6 | 2009-03-02 22:51:02 | [diff] [blame] | 12 | #include "net/proxy/proxy_config_service.h" |
[email protected] | 6104ea5d | 2011-04-27 21:37:12 | [diff] [blame] | 13 | #include "net/proxy/proxy_service.h" |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 14 | #include "testing/gtest/include/gtest/gtest.h" |
| 15 | |
[email protected] | 4648832 | 2012-10-30 03:22:20 | [diff] [blame] | 16 | namespace content { |
[email protected] | 9214555 | 2011-10-31 16:28:03 | [diff] [blame] | 17 | |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 18 | // This ProxyConfigService always returns "http://pac" as the PAC url to use. |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 19 | class MockProxyConfigService : public net::ProxyConfigService { |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 20 | public: |
dcheng | c2282aa | 2014-10-21 12:07:58 | [diff] [blame] | 21 | void AddObserver(Observer* observer) override {} |
| 22 | void RemoveObserver(Observer* observer) override {} |
| 23 | ConfigAvailability GetLatestProxyConfig(net::ProxyConfig* results) override { |
[email protected] | 11965500 | 2010-07-23 06:02:40 | [diff] [blame] | 24 | *results = net::ProxyConfig::CreateFromCustomPacURL(GURL("http://pac")); |
[email protected] | 3a29593d | 2011-04-11 10:07:52 | [diff] [blame] | 25 | return CONFIG_VALID; |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 26 | } |
| 27 | }; |
| 28 | |
[email protected] | ba780c1 | 2013-10-01 17:07:06 | [diff] [blame] | 29 | class TestResolveProxyMsgHelper : public ResolveProxyMsgHelper { |
| 30 | public: |
| 31 | TestResolveProxyMsgHelper( |
| 32 | net::ProxyService* proxy_service, |
| 33 | IPC::Listener* listener) |
| 34 | : ResolveProxyMsgHelper(proxy_service), |
| 35 | listener_(listener) {} |
dcheng | c2282aa | 2014-10-21 12:07:58 | [diff] [blame] | 36 | bool Send(IPC::Message* message) override { |
[email protected] | ba780c1 | 2013-10-01 17:07:06 | [diff] [blame] | 37 | listener_->OnMessageReceived(*message); |
| 38 | delete message; |
| 39 | return true; |
| 40 | } |
| 41 | |
| 42 | protected: |
dcheng | c2282aa | 2014-10-21 12:07:58 | [diff] [blame] | 43 | ~TestResolveProxyMsgHelper() override {} |
[email protected] | ba780c1 | 2013-10-01 17:07:06 | [diff] [blame] | 44 | |
| 45 | IPC::Listener* listener_; |
| 46 | }; |
| 47 | |
[email protected] | d84effeb | 2012-06-25 17:03:10 | [diff] [blame] | 48 | class ResolveProxyMsgHelperTest : public testing::Test, public IPC::Listener { |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 49 | public: |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 50 | struct PendingResult { |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 51 | PendingResult(bool result, |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 52 | const std::string& proxy_list) |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 53 | : result(result), proxy_list(proxy_list) { |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 54 | } |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 55 | |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 56 | bool result; |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 57 | std::string proxy_list; |
| 58 | }; |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 59 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 60 | ResolveProxyMsgHelperTest() |
sammc | e64b236 | 2015-04-29 03:50:23 | [diff] [blame] | 61 | : resolver_factory_(new net::MockAsyncProxyResolverFactory(false)), |
csharrison | b7e3a08 | 2015-09-22 19:13:04 | [diff] [blame] | 62 | service_( |
| 63 | new net::ProxyService(make_scoped_ptr(new MockProxyConfigService), |
| 64 | make_scoped_ptr(resolver_factory_), |
| 65 | NULL)), |
[email protected] | ba780c1 | 2013-10-01 17:07:06 | [diff] [blame] | 66 | helper_(new TestResolveProxyMsgHelper(service_.get(), this)), |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 67 | io_thread_(BrowserThread::IO, &message_loop_) { |
| 68 | test_sink_.AddFilter(this); |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 69 | } |
[email protected] | a692c6f | 2009-08-06 12:11:05 | [diff] [blame] | 70 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 71 | protected: |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 72 | const PendingResult* pending_result() const { return pending_result_.get(); } |
[email protected] | a692c6f | 2009-08-06 12:11:05 | [diff] [blame] | 73 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 74 | void clear_pending_result() { |
| 75 | pending_result_.reset(); |
[email protected] | a692c6f | 2009-08-06 12:11:05 | [diff] [blame] | 76 | } |
| 77 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 78 | IPC::Message* GenerateReply() { |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 79 | bool temp_bool; |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 80 | std::string temp_string; |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 81 | ViewHostMsg_ResolveProxy message(GURL(), &temp_bool, &temp_string); |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 82 | return IPC::SyncMessage::GenerateReply(&message); |
| 83 | } |
| 84 | |
sammc | e64b236 | 2015-04-29 03:50:23 | [diff] [blame] | 85 | net::MockAsyncProxyResolverFactory* resolver_factory_; |
sammc | 5dd160c | 2015-04-02 02:43:13 | [diff] [blame] | 86 | net::MockAsyncProxyResolver resolver_; |
[email protected] | 6104ea5d | 2011-04-27 21:37:12 | [diff] [blame] | 87 | scoped_ptr<net::ProxyService> service_; |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 88 | scoped_refptr<ResolveProxyMsgHelper> helper_; |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 89 | scoped_ptr<PendingResult> pending_result_; |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 90 | |
| 91 | private: |
dcheng | c2282aa | 2014-10-21 12:07:58 | [diff] [blame] | 92 | bool OnMessageReceived(const IPC::Message& msg) override { |
brettw | d5ca2bc | 2015-05-29 22:15:47 | [diff] [blame] | 93 | base::TupleTypes<ViewHostMsg_ResolveProxy::ReplyParam>::ValueTuple |
| 94 | reply_data; |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 95 | EXPECT_TRUE(ViewHostMsg_ResolveProxy::ReadReplyParam(&msg, &reply_data)); |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 96 | DCHECK(!pending_result_.get()); |
Avi Drissman | 95c2a1b7 | 2014-12-22 18:01:32 | [diff] [blame] | 97 | pending_result_.reset( |
brettw | d5ca2bc | 2015-05-29 22:15:47 | [diff] [blame] | 98 | new PendingResult(base::get<0>(reply_data), base::get<1>(reply_data))); |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 99 | test_sink_.ClearMessages(); |
| 100 | return true; |
| 101 | } |
| 102 | |
[email protected] | 1ef9001 | 2014-01-15 22:24:33 | [diff] [blame] | 103 | base::MessageLoopForIO message_loop_; |
[email protected] | 9214555 | 2011-10-31 16:28:03 | [diff] [blame] | 104 | BrowserThreadImpl io_thread_; |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 105 | IPC::TestSink test_sink_; |
[email protected] | a692c6f | 2009-08-06 12:11:05 | [diff] [blame] | 106 | }; |
| 107 | |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 108 | // Issue three sequential requests -- each should succeed. |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 109 | TEST_F(ResolveProxyMsgHelperTest, Sequential) { |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 110 | GURL url1("http://www.google1.com/"); |
| 111 | GURL url2("http://www.google2.com/"); |
| 112 | GURL url3("http://www.google3.com/"); |
| 113 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 114 | // Messages are deleted by the sink. |
| 115 | IPC::Message* msg1 = GenerateReply(); |
| 116 | IPC::Message* msg2 = GenerateReply(); |
| 117 | IPC::Message* msg3 = GenerateReply(); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 118 | |
| 119 | // Execute each request sequentially (so there are never 2 requests |
| 120 | // outstanding at the same time). |
| 121 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 122 | helper_->OnResolveProxy(url1, msg1); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 123 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 124 | // Finish ProxyService's initialization. |
sammc | e64b236 | 2015-04-29 03:50:23 | [diff] [blame] | 125 | ASSERT_EQ(1u, resolver_factory_->pending_requests().size()); |
| 126 | resolver_factory_->pending_requests()[0]->CompleteNowWithForwarder( |
| 127 | net::OK, &resolver_); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 128 | |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 129 | ASSERT_EQ(1u, resolver_.pending_requests().size()); |
| 130 | EXPECT_EQ(url1, resolver_.pending_requests()[0]->url()); |
| 131 | resolver_.pending_requests()[0]->results()->UseNamedProxy("result1:80"); |
| 132 | resolver_.pending_requests()[0]->CompleteNow(net::OK); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 133 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 134 | // Check result. |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 135 | EXPECT_EQ(true, pending_result()->result); |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 136 | EXPECT_EQ("PROXY result1:80", pending_result()->proxy_list); |
| 137 | clear_pending_result(); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 138 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 139 | helper_->OnResolveProxy(url2, msg2); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 140 | |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 141 | ASSERT_EQ(1u, resolver_.pending_requests().size()); |
| 142 | EXPECT_EQ(url2, resolver_.pending_requests()[0]->url()); |
| 143 | resolver_.pending_requests()[0]->results()->UseNamedProxy("result2:80"); |
| 144 | resolver_.pending_requests()[0]->CompleteNow(net::OK); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 145 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 146 | // Check result. |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 147 | EXPECT_EQ(true, pending_result()->result); |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 148 | EXPECT_EQ("PROXY result2:80", pending_result()->proxy_list); |
| 149 | clear_pending_result(); |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 150 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 151 | helper_->OnResolveProxy(url3, msg3); |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 152 | |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 153 | ASSERT_EQ(1u, resolver_.pending_requests().size()); |
| 154 | EXPECT_EQ(url3, resolver_.pending_requests()[0]->url()); |
| 155 | resolver_.pending_requests()[0]->results()->UseNamedProxy("result3:80"); |
| 156 | resolver_.pending_requests()[0]->CompleteNow(net::OK); |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 157 | |
| 158 | // Check result. |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 159 | EXPECT_EQ(true, pending_result()->result); |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 160 | EXPECT_EQ("PROXY result3:80", pending_result()->proxy_list); |
| 161 | clear_pending_result(); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 162 | } |
| 163 | |
| 164 | // Issue a request while one is already in progress -- should be queued. |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 165 | TEST_F(ResolveProxyMsgHelperTest, QueueRequests) { |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 166 | GURL url1("http://www.google1.com/"); |
| 167 | GURL url2("http://www.google2.com/"); |
| 168 | GURL url3("http://www.google3.com/"); |
| 169 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 170 | IPC::Message* msg1 = GenerateReply(); |
| 171 | IPC::Message* msg2 = GenerateReply(); |
| 172 | IPC::Message* msg3 = GenerateReply(); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 173 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 174 | // Start three requests. Since the proxy resolver is async, all the |
| 175 | // requests will be pending. |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 176 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 177 | helper_->OnResolveProxy(url1, msg1); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 178 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 179 | // Finish ProxyService's initialization. |
sammc | e64b236 | 2015-04-29 03:50:23 | [diff] [blame] | 180 | ASSERT_EQ(1u, resolver_factory_->pending_requests().size()); |
| 181 | resolver_factory_->pending_requests()[0]->CompleteNowWithForwarder( |
| 182 | net::OK, &resolver_); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 183 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 184 | helper_->OnResolveProxy(url2, msg2); |
| 185 | helper_->OnResolveProxy(url3, msg3); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 186 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 187 | // ResolveProxyHelper only keeps 1 request outstanding in ProxyService |
| 188 | // at a time. |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 189 | ASSERT_EQ(1u, resolver_.pending_requests().size()); |
| 190 | EXPECT_EQ(url1, resolver_.pending_requests()[0]->url()); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 191 | |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 192 | resolver_.pending_requests()[0]->results()->UseNamedProxy("result1:80"); |
| 193 | resolver_.pending_requests()[0]->CompleteNow(net::OK); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 194 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 195 | // Check result. |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 196 | EXPECT_EQ(true, pending_result()->result); |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 197 | EXPECT_EQ("PROXY result1:80", pending_result()->proxy_list); |
| 198 | clear_pending_result(); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 199 | |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 200 | ASSERT_EQ(1u, resolver_.pending_requests().size()); |
| 201 | EXPECT_EQ(url2, resolver_.pending_requests()[0]->url()); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 202 | |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 203 | resolver_.pending_requests()[0]->results()->UseNamedProxy("result2:80"); |
| 204 | resolver_.pending_requests()[0]->CompleteNow(net::OK); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 205 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 206 | // Check result. |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 207 | EXPECT_EQ(true, pending_result()->result); |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 208 | EXPECT_EQ("PROXY result2:80", pending_result()->proxy_list); |
| 209 | clear_pending_result(); |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 210 | |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 211 | ASSERT_EQ(1u, resolver_.pending_requests().size()); |
| 212 | EXPECT_EQ(url3, resolver_.pending_requests()[0]->url()); |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 213 | |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 214 | resolver_.pending_requests()[0]->results()->UseNamedProxy("result3:80"); |
| 215 | resolver_.pending_requests()[0]->CompleteNow(net::OK); |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 216 | |
| 217 | // Check result. |
[email protected] | 2dd868f | 2011-08-29 23:03:57 | [diff] [blame] | 218 | EXPECT_EQ(true, pending_result()->result); |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 219 | EXPECT_EQ("PROXY result3:80", pending_result()->proxy_list); |
| 220 | clear_pending_result(); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 221 | } |
| 222 | |
| 223 | // Delete the helper while a request is in progress, and others are pending. |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 224 | TEST_F(ResolveProxyMsgHelperTest, CancelPendingRequests) { |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 225 | GURL url1("http://www.google1.com/"); |
| 226 | GURL url2("http://www.google2.com/"); |
| 227 | GURL url3("http://www.google3.com/"); |
| 228 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 229 | // They will be deleted by the request's cancellation. |
| 230 | IPC::Message* msg1 = GenerateReply(); |
| 231 | IPC::Message* msg2 = GenerateReply(); |
| 232 | IPC::Message* msg3 = GenerateReply(); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 233 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 234 | // Start three requests. Since the proxy resolver is async, all the |
| 235 | // requests will be pending. |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 236 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 237 | helper_->OnResolveProxy(url1, msg1); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 238 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 239 | // Finish ProxyService's initialization. |
sammc | e64b236 | 2015-04-29 03:50:23 | [diff] [blame] | 240 | ASSERT_EQ(1u, resolver_factory_->pending_requests().size()); |
| 241 | resolver_factory_->pending_requests()[0]->CompleteNowWithForwarder( |
| 242 | net::OK, &resolver_); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 243 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 244 | helper_->OnResolveProxy(url2, msg2); |
| 245 | helper_->OnResolveProxy(url3, msg3); |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 246 | |
| 247 | // ResolveProxyHelper only keeps 1 request outstanding in ProxyService |
| 248 | // at a time. |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 249 | ASSERT_EQ(1u, resolver_.pending_requests().size()); |
| 250 | EXPECT_EQ(url1, resolver_.pending_requests()[0]->url()); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 251 | |
| 252 | // Delete the underlying ResolveProxyMsgHelper -- this should cancel all |
| 253 | // the requests which are outstanding. |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 254 | helper_ = NULL; |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 255 | |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 256 | // The pending requests sent to the proxy resolver should have been cancelled. |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 257 | |
eroman | 9c8f424 | 2016-02-29 21:16:54 | [diff] [blame] | 258 | EXPECT_EQ(0u, resolver_.pending_requests().size()); |
[email protected] | c6efbc6 | 2009-08-06 12:52:19 | [diff] [blame] | 259 | |
[email protected] | f6b224d | 2011-03-15 17:16:55 | [diff] [blame] | 260 | EXPECT_TRUE(pending_result() == NULL); |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 261 | |
| 262 | // It should also be the case that msg1, msg2, msg3 were deleted by the |
[email protected] | 64e95e1 | 2011-08-17 17:41:02 | [diff] [blame] | 263 | // cancellation. (Else will show up as a leak in Valgrind). |
[email protected] | 41b2780f | 2009-01-31 01:34:20 | [diff] [blame] | 264 | } |
[email protected] | 4648832 | 2012-10-30 03:22:20 | [diff] [blame] | 265 | |
| 266 | } // namespace content |