Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(580)

Unified Diff: chrome/browser/component_updater/test/url_request_post_interceptor.cc

Issue 56023005: First changelist of a series to migrate the component updater protocol (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Dump pings in all cases for easier debugging of failed tests. Created 7 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/component_updater/test/url_request_post_interceptor.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/component_updater/test/url_request_post_interceptor.cc
diff --git a/chrome/browser/component_updater/test/url_request_post_interceptor.cc b/chrome/browser/component_updater/test/url_request_post_interceptor.cc
index 885c9c69b2428f6c11b98425196403b7036355b0..4fead4ab9a1dc1d82ff531072063729725744a2d 100644
--- a/chrome/browser/component_updater/test/url_request_post_interceptor.cc
+++ b/chrome/browser/component_updater/test/url_request_post_interceptor.cc
@@ -3,16 +3,115 @@
// found in the LICENSE file.
#include "chrome/browser/component_updater/test/url_request_post_interceptor.h"
-
+#include "base/file_util.h"
+#include "base/strings/stringprintf.h"
+#include "base/synchronization/lock.h"
#include "content/public/test/test_browser_thread.h"
+#include "net/base/upload_bytes_element_reader.h"
#include "net/url_request/url_request.h"
#include "net/url_request/url_request_filter.h"
+#include "net/url_request/url_request_job_factory.h"
+#include "net/url_request/url_request_simple_job.h"
#include "net/url_request/url_request_test_util.h"
using content::BrowserThread;
+// Returns an empty response body for any request.
+class URLRequestMockJob : public net::URLRequestSimpleJob {
+ public:
+ URLRequestMockJob(net::URLRequest* request,
+ net::NetworkDelegate* network_delegate)
+ : net::URLRequestSimpleJob(request, network_delegate) {}
+
+ protected:
+ virtual int GetData(std::string* mime_type,
+ std::string* charset,
+ std::string* data,
+ const net::CompletionCallback& callback) const OVERRIDE {
+ mime_type->assign("text/plain");
+ charset->assign("US-ASCII");
+ data->clear();
+ return net::OK;
+ }
+
+ private:
+ virtual ~URLRequestMockJob() {}
+
+ DISALLOW_COPY_AND_ASSIGN(URLRequestMockJob);
+};
+
+class URLRequestPostInterceptor::Delegate
+ : public net::URLRequestJobFactory::ProtocolHandler {
+ public:
+ Delegate(const std::string& scheme, const std::string& hostname)
+ : hit_count_(0), scheme_(scheme), hostname_(hostname) {}
+
+ void Register() {
+ CHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
+ net::URLRequestFilter::GetInstance()->AddHostnameProtocolHandler(
+ scheme_, hostname_,
+ scoped_ptr<net::URLRequestJobFactory::ProtocolHandler>(this));
+ }
+
+ void Unregister() {
+ CHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
+ net::URLRequestFilter::GetInstance()->
+ RemoveHostnameHandler(scheme_, hostname_);
+ }
+
+ // Returns how many requests have been intercepted and captured.
+ int GetHitCount() const {
+ base::AutoLock auto_lock(hit_count_lock_);
+ DCHECK(hit_count_ == static_cast<int>(requests_.size()));
+ return hit_count_;
+ }
+
+ std::vector<std::string> GetRequests() const {
+ base::AutoLock auto_lock(hit_count_lock_);
+ return requests_;
+ }
+
+ private:
+ virtual ~Delegate() {}
+
+ virtual net::URLRequestJob* MaybeCreateJob(
+ net::URLRequest* request,
+ net::NetworkDelegate* network_delegate) const OVERRIDE {
+ CHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
+
+ if (!request->has_upload())
+ return NULL;
+
+ const net::UploadDataStream* stream = request->get_upload();
+ const net::UploadBytesElementReader* reader =
+ stream->element_readers()[0]->AsBytesReader();
+ const int size = reader->length();
+ scoped_refptr<net::IOBuffer> buffer(new net::IOBuffer(size));
+ const std::string request_body(reader->bytes());
+
+ {
+ base::AutoLock auto_lock(hit_count_lock_);
+ ++hit_count_;
+ requests_.push_back(request_body);
+ }
+
+ return new URLRequestMockJob(request, network_delegate);
+ }
+
+ mutable base::Lock hit_count_lock_;
+ mutable int hit_count_;
+ mutable std::vector<std::string> requests_;
cpu_(ooo_6.6-7.5) 2013/11/04 22:25:53 is it worth to have all the interesting members as
Sorin Jianu 2013/11/05 22:41:47 These members have to be mutable since the virtual
+
+ const std::string scheme_;
+ const std::string hostname_;
+
+ DISALLOW_COPY_AND_ASSIGN(Delegate);
+};
+
URLRequestPostInterceptor::URLRequestPostInterceptor(
- RequestCounter* counter) : delegate_(new Delegate(counter)) {
+ const std::string& scheme,
+ const std::string& hostname)
+ : delegate_(new Delegate(scheme, hostname)) {
BrowserThread::PostTask(BrowserThread::IO, FROM_HERE,
base::Bind(&Delegate::Register,
base::Unretained(delegate_)));
@@ -24,45 +123,25 @@ URLRequestPostInterceptor::~URLRequestPostInterceptor() {
base::Unretained(delegate_)));
}
-URLRequestPostInterceptor::Delegate::Delegate(
- RequestCounter* counter) : counter_(counter) {
+int URLRequestPostInterceptor::GetHitCount() const {
+ return delegate_->GetHitCount();
}
-void URLRequestPostInterceptor::Delegate::Register() {
- net::URLRequestFilter::GetInstance()->AddHostnameProtocolHandler(
- "http", "localhost2",
- scoped_ptr<net::URLRequestJobFactory::ProtocolHandler>(this));
+std::vector<std::string> URLRequestPostInterceptor::GetRequests() const {
+ return delegate_->GetRequests();
}
-void URLRequestPostInterceptor::Delegate::Unregister() {
- net::URLRequestFilter::GetInstance()->
- RemoveHostnameHandler("http", "localhost2");
-}
+std::string URLRequestPostInterceptor::GetRequestsAsString() const {
+ std::vector<std::string> requests(GetRequests());
-net::URLRequestJob* URLRequestPostInterceptor::Delegate::MaybeCreateJob(
- net::URLRequest* request,
- net::NetworkDelegate* network_delegate) const {
- CHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
- if (request->has_upload()) {
- counter_->Trial(request);
- return new URLRequestPingMockJob(request, network_delegate);
+ std::string s = "Requests are:";
+
+ int i = 0;
+ for (std::vector<std::string>::const_iterator it = requests.begin();
+ it != requests.end(); ++it) {
+ s.append(base::StringPrintf("\n (%d): %s", ++i, it->c_str()));
}
- return NULL;
-}
-URLRequestPingMockJob::URLRequestPingMockJob(
- net::URLRequest* request,
- net::NetworkDelegate* network_delegate)
- : net::URLRequestSimpleJob(request, network_delegate) {
+ return s;
}
-int URLRequestPingMockJob::GetData(
- std::string* mime_type,
- std::string* charset,
- std::string* data,
- const net::CompletionCallback& callback) const {
- mime_type->assign("text/plain");
- charset->assign("US-ASCII");
- data->assign(""); // There is no reason to have a response body.
- return net::OK;
-}
« no previous file with comments | « chrome/browser/component_updater/test/url_request_post_interceptor.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698