summaryrefslogtreecommitdiffstats
path: root/net/url_request/url_request_test_util.cc
diff options
context:
space:
mode:
authorerg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2011-01-25 23:48:06 +0000
committererg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2011-01-25 23:48:06 +0000
commit472ce96a4b839814ed93c26d35d07c78de019b17 (patch)
tree8355f2a490ce20c4be7485f40505544e3d602a26 /net/url_request/url_request_test_util.cc
parentb597956cd427a3b830a498c69602753ce6117119 (diff)
downloadchromium_src-472ce96a4b839814ed93c26d35d07c78de019b17.zip
chromium_src-472ce96a4b839814ed93c26d35d07c78de019b17.tar.gz
chromium_src-472ce96a4b839814ed93c26d35d07c78de019b17.tar.bz2
Clean up net unit testing code.
- Move code included from blah_unittest.h (where blah_unittest.cc has actual unittests) into their own files, often completely out-of-lining the definitions. - Remove anonymous namespaces from headers. - Reorder method declarations. - Make other unit test link against net_test_support instead of reaching in and including .h files in their targets directly. BUG=68682 TEST=compiles Review URL: http://codereview.chromium.org/6264013 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@72562 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/url_request/url_request_test_util.cc')
-rw-r--r--net/url_request/url_request_test_util.cc281
1 files changed, 281 insertions, 0 deletions
diff --git a/net/url_request/url_request_test_util.cc b/net/url_request/url_request_test_util.cc
new file mode 100644
index 0000000..099810a
--- /dev/null
+++ b/net/url_request/url_request_test_util.cc
@@ -0,0 +1,281 @@
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "net/url_request/url_request_test_util.h"
+
+#include "base/logging.h"
+#include "base/message_loop.h"
+#include "base/threading/thread.h"
+
+TestCookiePolicy::TestCookiePolicy(int options_bit_mask)
+ : ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)),
+ options_(options_bit_mask),
+ callback_(NULL) {
+}
+
+TestCookiePolicy::~TestCookiePolicy() {}
+
+int TestCookiePolicy::CanGetCookies(const GURL& url,
+ const GURL& first_party,
+ net::CompletionCallback* callback) {
+ if ((options_ & ASYNC) && callback) {
+ callback_ = callback;
+ MessageLoop::current()->PostTask(FROM_HERE,
+ method_factory_.NewRunnableMethod(
+ &TestCookiePolicy::DoGetCookiesPolicy, url, first_party));
+ return net::ERR_IO_PENDING;
+ }
+
+ if (options_ & NO_GET_COOKIES)
+ return net::ERR_ACCESS_DENIED;
+
+ return net::OK;
+}
+
+int TestCookiePolicy::CanSetCookie(const GURL& url,
+ const GURL& first_party,
+ const std::string& cookie_line,
+ net::CompletionCallback* callback) {
+ if ((options_ & ASYNC) && callback) {
+ callback_ = callback;
+ MessageLoop::current()->PostTask(FROM_HERE,
+ method_factory_.NewRunnableMethod(
+ &TestCookiePolicy::DoSetCookiePolicy, url, first_party,
+ cookie_line));
+ return net::ERR_IO_PENDING;
+ }
+
+ if (options_ & NO_SET_COOKIE)
+ return net::ERR_ACCESS_DENIED;
+
+ if (options_ & FORCE_SESSION)
+ return net::OK_FOR_SESSION_ONLY;
+
+ return net::OK;
+}
+
+void TestCookiePolicy::DoGetCookiesPolicy(const GURL& url,
+ const GURL& first_party) {
+ int policy = CanGetCookies(url, first_party, NULL);
+
+ DCHECK(callback_);
+ net::CompletionCallback* callback = callback_;
+ callback_ = NULL;
+ callback->Run(policy);
+}
+
+void TestCookiePolicy::DoSetCookiePolicy(const GURL& url,
+ const GURL& first_party,
+ const std::string& cookie_line) {
+ int policy = CanSetCookie(url, first_party, cookie_line, NULL);
+
+ DCHECK(callback_);
+ net::CompletionCallback* callback = callback_;
+ callback_ = NULL;
+ callback->Run(policy);
+}
+
+
+TestURLRequestContext::TestURLRequestContext() {
+ host_resolver_ =
+ net::CreateSystemHostResolver(net::HostResolver::kDefaultParallelism,
+ NULL, NULL);
+ proxy_service_ = net::ProxyService::CreateDirect();
+ Init();
+}
+
+TestURLRequestContext::TestURLRequestContext(const std::string& proxy) {
+ host_resolver_ =
+ net::CreateSystemHostResolver(net::HostResolver::kDefaultParallelism,
+ NULL, NULL);
+ net::ProxyConfig proxy_config;
+ proxy_config.proxy_rules().ParseFromString(proxy);
+ proxy_service_ = net::ProxyService::CreateFixed(proxy_config);
+ Init();
+}
+
+TestURLRequestContext::~TestURLRequestContext() {
+ delete ftp_transaction_factory_;
+ delete http_transaction_factory_;
+ delete http_auth_handler_factory_;
+ delete cert_verifier_;
+ delete host_resolver_;
+}
+
+void TestURLRequestContext::Init() {
+ cert_verifier_ = new net::CertVerifier;
+ ftp_transaction_factory_ = new net::FtpNetworkLayer(host_resolver_);
+ ssl_config_service_ = new net::SSLConfigServiceDefaults;
+ http_auth_handler_factory_ = net::HttpAuthHandlerFactory::CreateDefault(
+ host_resolver_);
+ http_transaction_factory_ = new net::HttpCache(
+ net::HttpNetworkLayer::CreateFactory(host_resolver_,
+ cert_verifier_,
+ NULL /* dnsrr_resolver */,
+ NULL /* dns_cert_checker */,
+ NULL /* ssl_host_info_factory */,
+ proxy_service_,
+ ssl_config_service_,
+ http_auth_handler_factory_,
+ network_delegate_,
+ NULL),
+ NULL /* net_log */,
+ net::HttpCache::DefaultBackend::InMemory(0));
+ // In-memory cookie store.
+ cookie_store_ = new net::CookieMonster(NULL, NULL);
+ accept_language_ = "en-us,fr";
+ accept_charset_ = "iso-8859-1,*,utf-8";
+}
+
+
+TestURLRequest::TestURLRequest(const GURL& url, Delegate* delegate)
+ : net::URLRequest(url, delegate) {
+ set_context(new TestURLRequestContext());
+}
+
+TestURLRequest::~TestURLRequest() {}
+
+TestDelegate::TestDelegate()
+ : cancel_in_rr_(false),
+ cancel_in_rs_(false),
+ cancel_in_rd_(false),
+ cancel_in_rd_pending_(false),
+ cancel_in_getcookiesblocked_(false),
+ cancel_in_setcookieblocked_(false),
+ quit_on_complete_(true),
+ quit_on_redirect_(false),
+ allow_certificate_errors_(false),
+ response_started_count_(0),
+ received_bytes_count_(0),
+ received_redirect_count_(0),
+ blocked_get_cookies_count_(0),
+ blocked_set_cookie_count_(0),
+ set_cookie_count_(0),
+ received_data_before_response_(false),
+ request_failed_(false),
+ have_certificate_errors_(false),
+ buf_(new net::IOBuffer(kBufferSize)) {
+}
+
+TestDelegate::~TestDelegate() {}
+
+void TestDelegate::OnReceivedRedirect(net::URLRequest* request,
+ const GURL& new_url,
+ bool* defer_redirect) {
+ received_redirect_count_++;
+ if (quit_on_redirect_) {
+ *defer_redirect = true;
+ MessageLoop::current()->PostTask(FROM_HERE, new MessageLoop::QuitTask());
+ } else if (cancel_in_rr_) {
+ request->Cancel();
+ }
+}
+
+void TestDelegate::OnAuthRequired(net::URLRequest* request,
+ net::AuthChallengeInfo* auth_info) {
+ if (!username_.empty() || !password_.empty()) {
+ request->SetAuth(username_, password_);
+ } else {
+ request->CancelAuth();
+ }
+}
+
+void TestDelegate::OnSSLCertificateError(net::URLRequest* request,
+ int cert_error,
+ net::X509Certificate* cert) {
+ // The caller can control whether it needs all SSL requests to go through,
+ // independent of any possible errors, or whether it wants SSL errors to
+ // cancel the request.
+ have_certificate_errors_ = true;
+ if (allow_certificate_errors_)
+ request->ContinueDespiteLastError();
+ else
+ request->Cancel();
+}
+
+void TestDelegate::OnGetCookies(net::URLRequest* request,
+ bool blocked_by_policy) {
+ if (blocked_by_policy) {
+ blocked_get_cookies_count_++;
+ if (cancel_in_getcookiesblocked_)
+ request->Cancel();
+ }
+}
+
+void TestDelegate::OnSetCookie(net::URLRequest* request,
+ const std::string& cookie_line,
+ const net::CookieOptions& options,
+ bool blocked_by_policy) {
+ if (blocked_by_policy) {
+ blocked_set_cookie_count_++;
+ if (cancel_in_setcookieblocked_)
+ request->Cancel();
+ } else {
+ set_cookie_count_++;
+ }
+}
+
+void TestDelegate::OnResponseStarted(net::URLRequest* request) {
+ // It doesn't make sense for the request to have IO pending at this point.
+ DCHECK(!request->status().is_io_pending());
+
+ response_started_count_++;
+ if (cancel_in_rs_) {
+ request->Cancel();
+ OnResponseCompleted(request);
+ } else if (!request->status().is_success()) {
+ DCHECK(request->status().status() == net::URLRequestStatus::FAILED ||
+ request->status().status() == net::URLRequestStatus::CANCELED);
+ request_failed_ = true;
+ OnResponseCompleted(request);
+ } else {
+ // Initiate the first read.
+ int bytes_read = 0;
+ if (request->Read(buf_, kBufferSize, &bytes_read))
+ OnReadCompleted(request, bytes_read);
+ else if (!request->status().is_io_pending())
+ OnResponseCompleted(request);
+ }
+}
+
+void TestDelegate::OnReadCompleted(net::URLRequest* request, int bytes_read) {
+ // It doesn't make sense for the request to have IO pending at this point.
+ DCHECK(!request->status().is_io_pending());
+
+ if (response_started_count_ == 0)
+ received_data_before_response_ = true;
+
+ if (cancel_in_rd_)
+ request->Cancel();
+
+ if (bytes_read >= 0) {
+ // There is data to read.
+ received_bytes_count_ += bytes_read;
+
+ // consume the data
+ data_received_.append(buf_->data(), bytes_read);
+ }
+
+ // If it was not end of stream, request to read more.
+ if (request->status().is_success() && bytes_read > 0) {
+ bytes_read = 0;
+ while (request->Read(buf_, kBufferSize, &bytes_read)) {
+ if (bytes_read > 0) {
+ data_received_.append(buf_->data(), bytes_read);
+ received_bytes_count_ += bytes_read;
+ } else {
+ break;
+ }
+ }
+ }
+ if (!request->status().is_io_pending())
+ OnResponseCompleted(request);
+ else if (cancel_in_rd_pending_)
+ request->Cancel();
+}
+
+void TestDelegate::OnResponseCompleted(net::URLRequest* request) {
+ if (quit_on_complete_)
+ MessageLoop::current()->PostTask(FROM_HERE, new MessageLoop::QuitTask());
+}