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
3 // found in the LICENSE file.
5 #ifndef NET_URL_REQUEST_URL_REQUEST_TEST_UTIL_H_
6 #define NET_URL_REQUEST_URL_REQUEST_TEST_UTIL_H_
13 #include "base/basictypes.h"
14 #include "base/compiler_specific.h"
15 #include "base/memory/ref_counted.h"
16 #include "base/message_loop/message_loop_proxy.h"
17 #include "base/path_service.h"
18 #include "base/strings/string16.h"
19 #include "base/strings/string_util.h"
20 #include "base/strings/utf_string_conversions.h"
21 #include "base/time/time.h"
22 #include "net/base/io_buffer.h"
23 #include "net/base/load_timing_info.h"
24 #include "net/base/net_errors.h"
25 #include "net/base/network_delegate.h"
26 #include "net/base/request_priority.h"
27 #include "net/cert/cert_verifier.h"
28 #include "net/cookies/cookie_monster.h"
29 #include "net/disk_cache/disk_cache.h"
30 #include "net/ftp/ftp_network_layer.h"
31 #include "net/http/http_auth_handler_factory.h"
32 #include "net/http/http_cache.h"
33 #include "net/http/http_network_layer.h"
34 #include "net/http/http_request_headers.h"
35 #include "net/proxy/proxy_service.h"
36 #include "net/ssl/ssl_config_service_defaults.h"
37 #include "net/url_request/url_request.h"
38 #include "net/url_request/url_request_context.h"
39 #include "net/url_request/url_request_context_getter.h"
40 #include "net/url_request/url_request_context_storage.h"
41 #include "net/url_request/url_request_job_factory.h"
42 #include "url/url_util.h"
44 using base::TimeDelta;
48 //-----------------------------------------------------------------------------
50 class TestURLRequestContext : public URLRequestContext {
52 TestURLRequestContext();
53 // Default constructor like TestURLRequestContext() but does not call
54 // Init() in case |delay_initialization| is true. This allows modifying the
55 // URLRequestContext before it is constructed completely. If
56 // |delay_initialization| is true, Init() needs be be called manually.
57 explicit TestURLRequestContext(bool delay_initialization);
58 virtual ~TestURLRequestContext();
62 ClientSocketFactory* client_socket_factory() {
63 return client_socket_factory_;
65 void set_client_socket_factory(ClientSocketFactory* factory) {
66 client_socket_factory_ = factory;
73 ClientSocketFactory* client_socket_factory_;
76 URLRequestContextStorage context_storage_;
79 //-----------------------------------------------------------------------------
81 // Used to return a dummy context, which lives on the message loop
82 // given in the constructor.
83 class TestURLRequestContextGetter : public URLRequestContextGetter {
85 // |network_task_runner| must not be NULL.
86 explicit TestURLRequestContextGetter(
87 const scoped_refptr<base::SingleThreadTaskRunner>& network_task_runner);
89 // Use to pass a pre-initialized |context|.
90 TestURLRequestContextGetter(
91 const scoped_refptr<base::SingleThreadTaskRunner>& network_task_runner,
92 scoped_ptr<TestURLRequestContext> context);
94 // URLRequestContextGetter implementation.
95 virtual TestURLRequestContext* GetURLRequestContext() OVERRIDE;
96 virtual scoped_refptr<base::SingleThreadTaskRunner>
97 GetNetworkTaskRunner() const OVERRIDE;
100 virtual ~TestURLRequestContextGetter();
103 const scoped_refptr<base::SingleThreadTaskRunner> network_task_runner_;
104 scoped_ptr<TestURLRequestContext> context_;
107 //-----------------------------------------------------------------------------
109 class TestURLRequest : public URLRequest {
111 TestURLRequest(const GURL& url,
112 RequestPriority priority,
114 TestURLRequestContext* context);
115 virtual ~TestURLRequest();
118 //-----------------------------------------------------------------------------
120 class TestDelegate : public URLRequest::Delegate {
123 virtual ~TestDelegate();
125 void set_cancel_in_received_redirect(bool val) { cancel_in_rr_ = val; }
126 void set_cancel_in_response_started(bool val) { cancel_in_rs_ = val; }
127 void set_cancel_in_received_data(bool val) { cancel_in_rd_ = val; }
128 void set_cancel_in_received_data_pending(bool val) {
129 cancel_in_rd_pending_ = val;
131 void set_quit_on_complete(bool val) { quit_on_complete_ = val; }
132 void set_quit_on_redirect(bool val) { quit_on_redirect_ = val; }
133 void set_allow_certificate_errors(bool val) {
134 allow_certificate_errors_ = val;
136 void set_credentials(const AuthCredentials& credentials) {
137 credentials_ = credentials;
141 const std::string& data_received() const { return data_received_; }
142 int bytes_received() const { return static_cast<int>(data_received_.size()); }
143 int response_started_count() const { return response_started_count_; }
144 int received_redirect_count() const { return received_redirect_count_; }
145 bool received_data_before_response() const {
146 return received_data_before_response_;
148 bool request_failed() const { return request_failed_; }
149 bool have_certificate_errors() const { return have_certificate_errors_; }
150 bool certificate_errors_are_fatal() const {
151 return certificate_errors_are_fatal_;
153 bool auth_required_called() const { return auth_required_; }
154 bool have_full_request_headers() const { return have_full_request_headers_; }
155 const HttpRequestHeaders& full_request_headers() const {
156 return full_request_headers_;
158 void ClearFullRequestHeaders();
160 // URLRequest::Delegate:
161 virtual void OnReceivedRedirect(URLRequest* request, const GURL& new_url,
162 bool* defer_redirect) OVERRIDE;
163 virtual void OnAuthRequired(URLRequest* request,
164 AuthChallengeInfo* auth_info) OVERRIDE;
165 // NOTE: |fatal| causes |certificate_errors_are_fatal_| to be set to true.
166 // (Unit tests use this as a post-condition.) But for policy, this method
167 // consults |allow_certificate_errors_|.
168 virtual void OnSSLCertificateError(URLRequest* request,
169 const SSLInfo& ssl_info,
170 bool fatal) OVERRIDE;
171 virtual void OnResponseStarted(URLRequest* request) OVERRIDE;
172 virtual void OnReadCompleted(URLRequest* request,
173 int bytes_read) OVERRIDE;
176 static const int kBufferSize = 4096;
178 virtual void OnResponseCompleted(URLRequest* request);
180 // options for controlling behavior
184 bool cancel_in_rd_pending_;
185 bool quit_on_complete_;
186 bool quit_on_redirect_;
187 bool allow_certificate_errors_;
188 AuthCredentials credentials_;
190 // tracks status of callbacks
191 int response_started_count_;
192 int received_bytes_count_;
193 int received_redirect_count_;
194 bool received_data_before_response_;
195 bool request_failed_;
196 bool have_certificate_errors_;
197 bool certificate_errors_are_fatal_;
199 std::string data_received_;
200 bool have_full_request_headers_;
201 HttpRequestHeaders full_request_headers_;
204 scoped_refptr<IOBuffer> buf_;
207 //-----------------------------------------------------------------------------
209 class TestNetworkDelegate : public NetworkDelegate {
212 NO_GET_COOKIES = 1 << 0,
213 NO_SET_COOKIE = 1 << 1,
216 TestNetworkDelegate();
217 virtual ~TestNetworkDelegate();
219 // Writes the LoadTimingInfo during the most recent call to OnBeforeRedirect.
220 bool GetLoadTimingInfoBeforeRedirect(
221 LoadTimingInfo* load_timing_info_before_redirect) const;
223 // Same as GetLoadTimingInfoBeforeRedirect, except for calls to
224 // AuthRequiredResponse.
225 bool GetLoadTimingInfoBeforeAuth(
226 LoadTimingInfo* load_timing_info_before_auth) const;
228 void set_cookie_options(int o) {cookie_options_bit_mask_ = o; }
230 int last_error() const { return last_error_; }
231 int error_count() const { return error_count_; }
232 int created_requests() const { return created_requests_; }
233 int destroyed_requests() const { return destroyed_requests_; }
234 int completed_requests() const { return completed_requests_; }
235 int blocked_get_cookies_count() const { return blocked_get_cookies_count_; }
236 int blocked_set_cookie_count() const { return blocked_set_cookie_count_; }
237 int set_cookie_count() const { return set_cookie_count_; }
241 virtual int OnBeforeURLRequest(URLRequest* request,
242 const CompletionCallback& callback,
243 GURL* new_url) OVERRIDE;
244 virtual int OnBeforeSendHeaders(URLRequest* request,
245 const CompletionCallback& callback,
246 HttpRequestHeaders* headers) OVERRIDE;
247 virtual void OnSendHeaders(URLRequest* request,
248 const HttpRequestHeaders& headers) OVERRIDE;
249 virtual int OnHeadersReceived(
251 const CompletionCallback& callback,
252 const HttpResponseHeaders* original_response_headers,
253 scoped_refptr<HttpResponseHeaders>* override_response_headers) OVERRIDE;
254 virtual void OnBeforeRedirect(URLRequest* request,
255 const GURL& new_location) OVERRIDE;
256 virtual void OnResponseStarted(URLRequest* request) OVERRIDE;
257 virtual void OnRawBytesRead(const URLRequest& request,
258 int bytes_read) OVERRIDE;
259 virtual void OnCompleted(URLRequest* request, bool started) OVERRIDE;
260 virtual void OnURLRequestDestroyed(URLRequest* request) OVERRIDE;
261 virtual void OnPACScriptError(int line_number,
262 const base::string16& error) OVERRIDE;
263 virtual NetworkDelegate::AuthRequiredResponse OnAuthRequired(
265 const AuthChallengeInfo& auth_info,
266 const AuthCallback& callback,
267 AuthCredentials* credentials) OVERRIDE;
268 virtual bool OnCanGetCookies(const URLRequest& request,
269 const CookieList& cookie_list) OVERRIDE;
270 virtual bool OnCanSetCookie(const URLRequest& request,
271 const std::string& cookie_line,
272 CookieOptions* options) OVERRIDE;
273 virtual bool OnCanAccessFile(const URLRequest& request,
274 const base::FilePath& path) const OVERRIDE;
275 virtual bool OnCanThrottleRequest(
276 const URLRequest& request) const OVERRIDE;
277 virtual int OnBeforeSocketStreamConnect(
278 SocketStream* stream,
279 const CompletionCallback& callback) OVERRIDE;
280 virtual void OnRequestWaitStateChange(const URLRequest& request,
281 RequestWaitState state) OVERRIDE;
283 void InitRequestStatesIfNew(int request_id);
287 int created_requests_;
288 int destroyed_requests_;
289 int completed_requests_;
290 int cookie_options_bit_mask_;
291 int blocked_get_cookies_count_;
292 int blocked_set_cookie_count_;
293 int set_cookie_count_;
295 // NetworkDelegate callbacks happen in a particular order (e.g.
296 // OnBeforeURLRequest is always called before OnBeforeSendHeaders).
297 // This bit-set indicates for each request id (key) what events may be sent
299 std::map<int, int> next_states_;
301 // A log that records for each request id (key) the order in which On...
302 // functions were called.
303 std::map<int, std::string> event_order_;
305 LoadTimingInfo load_timing_info_before_redirect_;
306 bool has_load_timing_info_before_redirect_;
308 LoadTimingInfo load_timing_info_before_auth_;
309 bool has_load_timing_info_before_auth_;
312 // Overrides the host used by the LocalHttpTestServer in
313 // url_request_unittest.cc . This is used by the chrome_frame_net_tests due to
314 // a mysterious bug when tests execute over the loopback adapter. See
315 // http://crbug.com/114369 .
316 class ScopedCustomUrlRequestTestHttpHost {
318 // Sets the host name to be used. The previous hostname will be stored and
319 // restored upon destruction. Note that if the lifetimes of two or more
320 // instances of this class overlap, they must be strictly nested.
321 explicit ScopedCustomUrlRequestTestHttpHost(const std::string& new_value);
323 ~ScopedCustomUrlRequestTestHttpHost();
325 // Returns the current value to be used by HTTP tests in
326 // url_request_unittest.cc .
327 static const std::string& value();
330 static std::string value_;
331 const std::string old_value_;
332 const std::string new_value_;
334 DISALLOW_COPY_AND_ASSIGN(ScopedCustomUrlRequestTestHttpHost);
337 //-----------------------------------------------------------------------------
339 // A simple ProtocolHandler that returns a pre-built URLRequestJob only once.
340 class TestJobInterceptor : public URLRequestJobFactory::ProtocolHandler {
342 TestJobInterceptor();
344 virtual URLRequestJob* MaybeCreateJob(
346 NetworkDelegate* network_delegate) const OVERRIDE;
347 void set_main_intercept_job(URLRequestJob* job);
350 mutable URLRequestJob* main_intercept_job_;
355 #endif // NET_URL_REQUEST_URL_REQUEST_TEST_UTIL_H_