// Copyright (c) 2012 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. #ifndef NET_PROXY_MOCK_PROXY_RESOLVER_H_ #define NET_PROXY_MOCK_PROXY_RESOLVER_H_ #include #include "base/memory/scoped_ptr.h" #include "net/base/net_errors.h" #include "net/proxy/proxy_resolver.h" #include "url/gurl.h" namespace base { class MessageLoop; } namespace net { // Asynchronous mock proxy resolver. All requests complete asynchronously, // user must call Request::CompleteNow() on a pending request to signal it. class MockAsyncProxyResolverBase : public ProxyResolver { public: class Request : public base::RefCounted { public: Request(MockAsyncProxyResolverBase* resolver, const GURL& url, ProxyInfo* results, const net::CompletionCallback& callback); const GURL& url() const { return url_; } ProxyInfo* results() const { return results_; } const net::CompletionCallback& callback() const { return callback_; } void CompleteNow(int rv); private: friend class base::RefCounted; virtual ~Request(); MockAsyncProxyResolverBase* resolver_; const GURL url_; ProxyInfo* results_; net::CompletionCallback callback_; base::MessageLoop* origin_loop_; }; class SetPacScriptRequest { public: SetPacScriptRequest( MockAsyncProxyResolverBase* resolver, const scoped_refptr& script_data, const net::CompletionCallback& callback); ~SetPacScriptRequest(); const ProxyResolverScriptData* script_data() const { return script_data_.get(); } void CompleteNow(int rv); private: MockAsyncProxyResolverBase* resolver_; const scoped_refptr script_data_; net::CompletionCallback callback_; base::MessageLoop* origin_loop_; }; typedef std::vector > RequestsList; virtual ~MockAsyncProxyResolverBase(); // ProxyResolver implementation. virtual int GetProxyForURL(const GURL& url, ProxyInfo* results, const net::CompletionCallback& callback, RequestHandle* request_handle, const BoundNetLog& /*net_log*/) OVERRIDE; virtual void CancelRequest(RequestHandle request_handle) OVERRIDE; virtual LoadState GetLoadState(RequestHandle request_handle) const OVERRIDE; virtual int SetPacScript( const scoped_refptr& script_data, const net::CompletionCallback& callback) OVERRIDE; virtual void CancelSetPacScript() OVERRIDE; const RequestsList& pending_requests() const { return pending_requests_; } const RequestsList& cancelled_requests() const { return cancelled_requests_; } SetPacScriptRequest* pending_set_pac_script_request() const; bool has_pending_set_pac_script_request() const { return pending_set_pac_script_request_.get() != NULL; } void RemovePendingRequest(Request* request); void RemovePendingSetPacScriptRequest(SetPacScriptRequest* request); protected: explicit MockAsyncProxyResolverBase(bool expects_pac_bytes); private: RequestsList pending_requests_; RequestsList cancelled_requests_; scoped_ptr pending_set_pac_script_request_; }; class MockAsyncProxyResolver : public MockAsyncProxyResolverBase { public: MockAsyncProxyResolver() : MockAsyncProxyResolverBase(false /*expects_pac_bytes*/) {} }; class MockAsyncProxyResolverExpectsBytes : public MockAsyncProxyResolverBase { public: MockAsyncProxyResolverExpectsBytes() : MockAsyncProxyResolverBase(true /*expects_pac_bytes*/) {} }; } // namespace net #endif // NET_PROXY_MOCK_PROXY_RESOLVER_H_