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 "net/proxy/mock_proxy_resolver.h" | 5 #include "net/proxy/mock_proxy_resolver.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "base/message_loop.h" | 8 #include "base/message_loop.h" |
9 | 9 |
10 namespace net { | 10 namespace net { |
11 | 11 |
12 MockAsyncProxyResolverBase::Request::Request( | 12 MockAsyncProxyResolverBase::Request::Request( |
13 MockAsyncProxyResolverBase* resolver, | 13 MockAsyncProxyResolverBase* resolver, const GURL& url, ProxyInfo* results, |
14 const GURL& url, | 14 const CompletionCallback& callback) |
15 ProxyInfo* results, | |
16 OldCompletionCallback* callback) | |
17 : resolver_(resolver), | 15 : resolver_(resolver), |
18 url_(url), | 16 url_(url), |
19 results_(results), | 17 results_(results), |
20 callback_(callback), | 18 callback_(callback), |
21 origin_loop_(MessageLoop::current()) { | 19 origin_loop_(MessageLoop::current()) { |
22 } | 20 } |
23 | 21 |
24 void MockAsyncProxyResolverBase::Request::CompleteNow(int rv) { | 22 void MockAsyncProxyResolverBase::Request::CompleteNow(int rv) { |
25 OldCompletionCallback* callback = callback_; | 23 CompletionCallback callback = callback_; |
26 | 24 |
27 // May delete |this|. | 25 // May delete |this|. |
28 resolver_->RemovePendingRequest(this); | 26 resolver_->RemovePendingRequest(this); |
29 | 27 |
30 callback->Run(rv); | 28 callback.Run(rv); |
31 } | 29 } |
32 | 30 |
33 MockAsyncProxyResolverBase::Request::~Request() {} | 31 MockAsyncProxyResolverBase::Request::~Request() {} |
34 | 32 |
35 | 33 |
36 MockAsyncProxyResolverBase::SetPacScriptRequest::SetPacScriptRequest( | 34 MockAsyncProxyResolverBase::SetPacScriptRequest::SetPacScriptRequest( |
37 MockAsyncProxyResolverBase* resolver, | 35 MockAsyncProxyResolverBase* resolver, |
38 const scoped_refptr<ProxyResolverScriptData>& script_data, | 36 const scoped_refptr<ProxyResolverScriptData>& script_data, |
39 OldCompletionCallback* callback) | 37 const CompletionCallback& callback) |
40 : resolver_(resolver), | 38 : resolver_(resolver), |
41 script_data_(script_data), | 39 script_data_(script_data), |
42 callback_(callback), | 40 callback_(callback), |
43 origin_loop_(MessageLoop::current()) { | 41 origin_loop_(MessageLoop::current()) { |
44 } | 42 } |
45 | 43 |
46 MockAsyncProxyResolverBase::SetPacScriptRequest::~SetPacScriptRequest() {} | 44 MockAsyncProxyResolverBase::SetPacScriptRequest::~SetPacScriptRequest() {} |
47 | 45 |
48 void MockAsyncProxyResolverBase::SetPacScriptRequest::CompleteNow(int rv) { | 46 void MockAsyncProxyResolverBase::SetPacScriptRequest::CompleteNow(int rv) { |
49 OldCompletionCallback* callback = callback_; | 47 CompletionCallback callback = callback_; |
50 | 48 |
51 // Will delete |this|. | 49 // Will delete |this|. |
52 resolver_->RemovePendingSetPacScriptRequest(this); | 50 resolver_->RemovePendingSetPacScriptRequest(this); |
53 | 51 |
54 callback->Run(rv); | 52 callback.Run(rv); |
55 } | 53 } |
56 | 54 |
57 MockAsyncProxyResolverBase::~MockAsyncProxyResolverBase() {} | 55 MockAsyncProxyResolverBase::~MockAsyncProxyResolverBase() {} |
58 | 56 |
59 int MockAsyncProxyResolverBase::GetProxyForURL(const GURL& url, | 57 int MockAsyncProxyResolverBase::GetProxyForURL( |
60 ProxyInfo* results, | 58 const GURL& url, ProxyInfo* results, const CompletionCallback& callback, |
61 OldCompletionCallback* callback, | 59 RequestHandle* request_handle, const BoundNetLog& /*net_log*/) { |
62 RequestHandle* request_handle, | |
63 const BoundNetLog& /*net_log*/) { | |
64 scoped_refptr<Request> request = new Request(this, url, results, callback); | 60 scoped_refptr<Request> request = new Request(this, url, results, callback); |
65 pending_requests_.push_back(request); | 61 pending_requests_.push_back(request); |
66 | 62 |
67 if (request_handle) | 63 if (request_handle) |
68 *request_handle = reinterpret_cast<RequestHandle>(request.get()); | 64 *request_handle = reinterpret_cast<RequestHandle>(request.get()); |
69 | 65 |
70 // Test code completes the request by calling request->CompleteNow(). | 66 // Test code completes the request by calling request->CompleteNow(). |
71 return ERR_IO_PENDING; | 67 return ERR_IO_PENDING; |
72 } | 68 } |
73 | 69 |
(...skipping 10 matching lines...) Expand all Loading... |
84 } | 80 } |
85 | 81 |
86 LoadState MockAsyncProxyResolverBase::GetLoadStateThreadSafe( | 82 LoadState MockAsyncProxyResolverBase::GetLoadStateThreadSafe( |
87 RequestHandle request_handle) const { | 83 RequestHandle request_handle) const { |
88 NOTREACHED(); | 84 NOTREACHED(); |
89 return LOAD_STATE_IDLE; | 85 return LOAD_STATE_IDLE; |
90 } | 86 } |
91 | 87 |
92 int MockAsyncProxyResolverBase::SetPacScript( | 88 int MockAsyncProxyResolverBase::SetPacScript( |
93 const scoped_refptr<ProxyResolverScriptData>& script_data, | 89 const scoped_refptr<ProxyResolverScriptData>& script_data, |
94 OldCompletionCallback* callback) { | 90 const CompletionCallback& callback) { |
95 DCHECK(!pending_set_pac_script_request_.get()); | 91 DCHECK(!pending_set_pac_script_request_.get()); |
96 pending_set_pac_script_request_.reset( | 92 pending_set_pac_script_request_.reset( |
97 new SetPacScriptRequest(this, script_data, callback)); | 93 new SetPacScriptRequest(this, script_data, callback)); |
98 // Finished when user calls SetPacScriptRequest::CompleteNow(). | 94 // Finished when user calls SetPacScriptRequest::CompleteNow(). |
99 return ERR_IO_PENDING; | 95 return ERR_IO_PENDING; |
100 } | 96 } |
101 | 97 |
102 void MockAsyncProxyResolverBase::CancelSetPacScript() { | 98 void MockAsyncProxyResolverBase::CancelSetPacScript() { |
103 // Do nothing (caller was responsible for completing the request). | 99 // Do nothing (caller was responsible for completing the request). |
104 } | 100 } |
(...skipping 13 matching lines...) Expand all Loading... |
118 void MockAsyncProxyResolverBase::RemovePendingSetPacScriptRequest( | 114 void MockAsyncProxyResolverBase::RemovePendingSetPacScriptRequest( |
119 SetPacScriptRequest* request) { | 115 SetPacScriptRequest* request) { |
120 DCHECK_EQ(request, pending_set_pac_script_request()); | 116 DCHECK_EQ(request, pending_set_pac_script_request()); |
121 pending_set_pac_script_request_.reset(); | 117 pending_set_pac_script_request_.reset(); |
122 } | 118 } |
123 | 119 |
124 MockAsyncProxyResolverBase::MockAsyncProxyResolverBase(bool expects_pac_bytes) | 120 MockAsyncProxyResolverBase::MockAsyncProxyResolverBase(bool expects_pac_bytes) |
125 : ProxyResolver(expects_pac_bytes) {} | 121 : ProxyResolver(expects_pac_bytes) {} |
126 | 122 |
127 } // namespace net | 123 } // namespace net |
OLD | NEW |