OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "content/browser/resolve_proxy_msg_helper.h" | 5 #include "content/browser/resolve_proxy_msg_helper.h" |
6 | 6 |
7 #include "content/browser/browser_thread_impl.h" | 7 #include "content/browser/browser_thread_impl.h" |
8 #include "content/common/view_messages.h" | 8 #include "content/common/view_messages.h" |
9 #include "ipc/ipc_test_sink.h" | 9 #include "ipc/ipc_test_sink.h" |
10 #include "net/base/net_errors.h" | 10 #include "net/base/net_errors.h" |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
51 PendingResult(bool result, | 51 PendingResult(bool result, |
52 const std::string& proxy_list) | 52 const std::string& proxy_list) |
53 : result(result), proxy_list(proxy_list) { | 53 : result(result), proxy_list(proxy_list) { |
54 } | 54 } |
55 | 55 |
56 bool result; | 56 bool result; |
57 std::string proxy_list; | 57 std::string proxy_list; |
58 }; | 58 }; |
59 | 59 |
60 ResolveProxyMsgHelperTest() | 60 ResolveProxyMsgHelperTest() |
61 : service_(new net::ProxyService( | 61 : resolver_factory_(new net::MockAsyncProxyResolverFactory(false)), |
62 new MockProxyConfigService, | 62 service_(new net::ProxyService(new MockProxyConfigService, |
63 make_scoped_ptr( | 63 make_scoped_ptr(resolver_factory_), |
64 new net::ForwardingProxyResolverFactory(&resolver_)), | 64 NULL)), |
65 NULL)), | |
66 helper_(new TestResolveProxyMsgHelper(service_.get(), this)), | 65 helper_(new TestResolveProxyMsgHelper(service_.get(), this)), |
67 io_thread_(BrowserThread::IO, &message_loop_) { | 66 io_thread_(BrowserThread::IO, &message_loop_) { |
68 test_sink_.AddFilter(this); | 67 test_sink_.AddFilter(this); |
69 } | 68 } |
70 | 69 |
71 protected: | 70 protected: |
72 const PendingResult* pending_result() const { return pending_result_.get(); } | 71 const PendingResult* pending_result() const { return pending_result_.get(); } |
73 | 72 |
74 void clear_pending_result() { | 73 void clear_pending_result() { |
75 pending_result_.reset(); | 74 pending_result_.reset(); |
76 } | 75 } |
77 | 76 |
78 IPC::Message* GenerateReply() { | 77 IPC::Message* GenerateReply() { |
79 bool temp_bool; | 78 bool temp_bool; |
80 std::string temp_string; | 79 std::string temp_string; |
81 ViewHostMsg_ResolveProxy message(GURL(), &temp_bool, &temp_string); | 80 ViewHostMsg_ResolveProxy message(GURL(), &temp_bool, &temp_string); |
82 return IPC::SyncMessage::GenerateReply(&message); | 81 return IPC::SyncMessage::GenerateReply(&message); |
83 } | 82 } |
84 | 83 |
| 84 net::MockAsyncProxyResolverFactory* resolver_factory_; |
85 net::MockAsyncProxyResolver resolver_; | 85 net::MockAsyncProxyResolver resolver_; |
86 scoped_ptr<net::ProxyService> service_; | 86 scoped_ptr<net::ProxyService> service_; |
87 scoped_refptr<ResolveProxyMsgHelper> helper_; | 87 scoped_refptr<ResolveProxyMsgHelper> helper_; |
88 scoped_ptr<PendingResult> pending_result_; | 88 scoped_ptr<PendingResult> pending_result_; |
89 | 89 |
90 private: | 90 private: |
91 bool OnMessageReceived(const IPC::Message& msg) override { | 91 bool OnMessageReceived(const IPC::Message& msg) override { |
92 TupleTypes<ViewHostMsg_ResolveProxy::ReplyParam>::ValueTuple reply_data; | 92 TupleTypes<ViewHostMsg_ResolveProxy::ReplyParam>::ValueTuple reply_data; |
93 EXPECT_TRUE(ViewHostMsg_ResolveProxy::ReadReplyParam(&msg, &reply_data)); | 93 EXPECT_TRUE(ViewHostMsg_ResolveProxy::ReadReplyParam(&msg, &reply_data)); |
94 DCHECK(!pending_result_.get()); | 94 DCHECK(!pending_result_.get()); |
(...skipping 18 matching lines...) Expand all Loading... |
113 IPC::Message* msg1 = GenerateReply(); | 113 IPC::Message* msg1 = GenerateReply(); |
114 IPC::Message* msg2 = GenerateReply(); | 114 IPC::Message* msg2 = GenerateReply(); |
115 IPC::Message* msg3 = GenerateReply(); | 115 IPC::Message* msg3 = GenerateReply(); |
116 | 116 |
117 // Execute each request sequentially (so there are never 2 requests | 117 // Execute each request sequentially (so there are never 2 requests |
118 // outstanding at the same time). | 118 // outstanding at the same time). |
119 | 119 |
120 helper_->OnResolveProxy(url1, msg1); | 120 helper_->OnResolveProxy(url1, msg1); |
121 | 121 |
122 // Finish ProxyService's initialization. | 122 // Finish ProxyService's initialization. |
123 resolver_.pending_set_pac_script_request()->CompleteNow(net::OK); | 123 ASSERT_EQ(1u, resolver_factory_->pending_requests().size()); |
| 124 resolver_factory_->pending_requests()[0]->CompleteNowWithForwarder( |
| 125 net::OK, &resolver_); |
124 | 126 |
125 ASSERT_EQ(1u, resolver_.pending_requests().size()); | 127 ASSERT_EQ(1u, resolver_.pending_requests().size()); |
126 EXPECT_EQ(url1, resolver_.pending_requests()[0]->url()); | 128 EXPECT_EQ(url1, resolver_.pending_requests()[0]->url()); |
127 resolver_.pending_requests()[0]->results()->UseNamedProxy("result1:80"); | 129 resolver_.pending_requests()[0]->results()->UseNamedProxy("result1:80"); |
128 resolver_.pending_requests()[0]->CompleteNow(net::OK); | 130 resolver_.pending_requests()[0]->CompleteNow(net::OK); |
129 | 131 |
130 // Check result. | 132 // Check result. |
131 EXPECT_EQ(true, pending_result()->result); | 133 EXPECT_EQ(true, pending_result()->result); |
132 EXPECT_EQ("PROXY result1:80", pending_result()->proxy_list); | 134 EXPECT_EQ("PROXY result1:80", pending_result()->proxy_list); |
133 clear_pending_result(); | 135 clear_pending_result(); |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
166 IPC::Message* msg1 = GenerateReply(); | 168 IPC::Message* msg1 = GenerateReply(); |
167 IPC::Message* msg2 = GenerateReply(); | 169 IPC::Message* msg2 = GenerateReply(); |
168 IPC::Message* msg3 = GenerateReply(); | 170 IPC::Message* msg3 = GenerateReply(); |
169 | 171 |
170 // Start three requests. Since the proxy resolver is async, all the | 172 // Start three requests. Since the proxy resolver is async, all the |
171 // requests will be pending. | 173 // requests will be pending. |
172 | 174 |
173 helper_->OnResolveProxy(url1, msg1); | 175 helper_->OnResolveProxy(url1, msg1); |
174 | 176 |
175 // Finish ProxyService's initialization. | 177 // Finish ProxyService's initialization. |
176 resolver_.pending_set_pac_script_request()->CompleteNow(net::OK); | 178 ASSERT_EQ(1u, resolver_factory_->pending_requests().size()); |
| 179 resolver_factory_->pending_requests()[0]->CompleteNowWithForwarder( |
| 180 net::OK, &resolver_); |
177 | 181 |
178 helper_->OnResolveProxy(url2, msg2); | 182 helper_->OnResolveProxy(url2, msg2); |
179 helper_->OnResolveProxy(url3, msg3); | 183 helper_->OnResolveProxy(url3, msg3); |
180 | 184 |
181 // ResolveProxyHelper only keeps 1 request outstanding in ProxyService | 185 // ResolveProxyHelper only keeps 1 request outstanding in ProxyService |
182 // at a time. | 186 // at a time. |
183 ASSERT_EQ(1u, resolver_.pending_requests().size()); | 187 ASSERT_EQ(1u, resolver_.pending_requests().size()); |
184 EXPECT_EQ(url1, resolver_.pending_requests()[0]->url()); | 188 EXPECT_EQ(url1, resolver_.pending_requests()[0]->url()); |
185 | 189 |
186 resolver_.pending_requests()[0]->results()->UseNamedProxy("result1:80"); | 190 resolver_.pending_requests()[0]->results()->UseNamedProxy("result1:80"); |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
224 IPC::Message* msg1 = GenerateReply(); | 228 IPC::Message* msg1 = GenerateReply(); |
225 IPC::Message* msg2 = GenerateReply(); | 229 IPC::Message* msg2 = GenerateReply(); |
226 IPC::Message* msg3 = GenerateReply(); | 230 IPC::Message* msg3 = GenerateReply(); |
227 | 231 |
228 // Start three requests. Since the proxy resolver is async, all the | 232 // Start three requests. Since the proxy resolver is async, all the |
229 // requests will be pending. | 233 // requests will be pending. |
230 | 234 |
231 helper_->OnResolveProxy(url1, msg1); | 235 helper_->OnResolveProxy(url1, msg1); |
232 | 236 |
233 // Finish ProxyService's initialization. | 237 // Finish ProxyService's initialization. |
234 resolver_.pending_set_pac_script_request()->CompleteNow(net::OK); | 238 ASSERT_EQ(1u, resolver_factory_->pending_requests().size()); |
| 239 resolver_factory_->pending_requests()[0]->CompleteNowWithForwarder( |
| 240 net::OK, &resolver_); |
235 | 241 |
236 helper_->OnResolveProxy(url2, msg2); | 242 helper_->OnResolveProxy(url2, msg2); |
237 helper_->OnResolveProxy(url3, msg3); | 243 helper_->OnResolveProxy(url3, msg3); |
238 | 244 |
239 // ResolveProxyHelper only keeps 1 request outstanding in ProxyService | 245 // ResolveProxyHelper only keeps 1 request outstanding in ProxyService |
240 // at a time. | 246 // at a time. |
241 ASSERT_EQ(1u, resolver_.pending_requests().size()); | 247 ASSERT_EQ(1u, resolver_.pending_requests().size()); |
242 EXPECT_EQ(url1, resolver_.pending_requests()[0]->url()); | 248 EXPECT_EQ(url1, resolver_.pending_requests()[0]->url()); |
243 | 249 |
244 // Delete the underlying ResolveProxyMsgHelper -- this should cancel all | 250 // Delete the underlying ResolveProxyMsgHelper -- this should cancel all |
245 // the requests which are outstanding. | 251 // the requests which are outstanding. |
246 helper_ = NULL; | 252 helper_ = NULL; |
247 | 253 |
248 // The pending requests sent to the proxy resolver should have been cancelled. | 254 // The pending requests sent to the proxy resolver should have been cancelled. |
249 | 255 |
250 EXPECT_EQ(0u, resolver_.pending_requests().size()); | 256 EXPECT_EQ(0u, resolver_.pending_requests().size()); |
251 | 257 |
252 EXPECT_TRUE(pending_result() == NULL); | 258 EXPECT_TRUE(pending_result() == NULL); |
253 | 259 |
254 // It should also be the case that msg1, msg2, msg3 were deleted by the | 260 // It should also be the case that msg1, msg2, msg3 were deleted by the |
255 // cancellation. (Else will show up as a leak in Valgrind). | 261 // cancellation. (Else will show up as a leak in Valgrind). |
256 } | 262 } |
257 | 263 |
258 } // namespace content | 264 } // namespace content |
OLD | NEW |