diff options
author | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-15 18:57:48 +0000 |
---|---|---|
committer | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-15 18:57:48 +0000 |
commit | 94486c00c7ee5ed1e9e4cb28f27ed447ffe20e96 (patch) | |
tree | 41f9fb0a0a88caa2fc73eba88c95253f374fc2da /net/base | |
parent | 1df8d42d4d36358480f3a9c86e22d43a3da36c53 (diff) | |
download | chromium_src-94486c00c7ee5ed1e9e4cb28f27ed447ffe20e96.zip chromium_src-94486c00c7ee5ed1e9e4cb28f27ed447ffe20e96.tar.gz chromium_src-94486c00c7ee5ed1e9e4cb28f27ed447ffe20e96.tar.bz2 |
Make TCPClientSocketPool own the ConnectingSockets.
Re-enable the disabled URLRequest tests.
BUG=http://crbug.com/13952
TEST=covered by existing tests
Review URL: http://codereview.chromium.org/126065
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@18414 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/base')
-rw-r--r-- | net/base/tcp_client_socket_pool.cc | 62 | ||||
-rw-r--r-- | net/base/tcp_client_socket_pool.h | 10 |
2 files changed, 29 insertions, 43 deletions
diff --git a/net/base/tcp_client_socket_pool.cc b/net/base/tcp_client_socket_pool.cc index 7dadd4c..d35c71a 100644 --- a/net/base/tcp_client_socket_pool.cc +++ b/net/base/tcp_client_socket_pool.cc @@ -45,20 +45,15 @@ TCPClientSocketPool::ConnectingSocket::ConnectingSocket( callback_(this, &TCPClientSocketPool::ConnectingSocket::OnIOComplete)), pool_(pool), - resolver_(pool->GetHostResolver()), - canceled_(false) { - CHECK(!ContainsKey(pool_->connecting_socket_map_, handle)); - pool_->connecting_socket_map_[handle] = this; -} + resolver_(pool->GetHostResolver()) {} TCPClientSocketPool::ConnectingSocket::~ConnectingSocket() { - if (!canceled_) - pool_->connecting_socket_map_.erase(handle_); + // We don't worry about cancelling the host resolution and TCP connect, since + // ~SingleRequestHostResolver and ~ClientSocket will take care of it. } int TCPClientSocketPool::ConnectingSocket::Connect( const HostResolver::RequestInfo& resolve_info) { - CHECK(!canceled_); int rv = resolver_.Resolve(resolve_info, &addresses_, &callback_); if (rv != ERR_IO_PENDING) rv = OnIOCompleteInternal(rv, true /* synchronous */); @@ -73,30 +68,14 @@ int TCPClientSocketPool::ConnectingSocket::OnIOCompleteInternal( int result, bool synchronous) { CHECK(result != ERR_IO_PENDING); - if (canceled_) { - // We got canceled, so bail out. - delete this; - return result; - } - GroupMap::iterator group_it = pool_->group_map_.find(group_name_); - if (group_it == pool_->group_map_.end()) { - // The request corresponding to this ConnectingSocket has been canceled. - // Stop bothering with it. - delete this; - return result; - } + CHECK(group_it != pool_->group_map_.end()); Group& group = group_it->second; RequestMap* request_map = &group.connecting_requests; RequestMap::iterator it = request_map->find(handle_); - if (it == request_map->end()) { - // The request corresponding to this ConnectingSocket has been canceled. - // Stop bothering with it. - delete this; - return result; - } + CHECK(it != request_map->end()); if (result == OK && it->second.load_state == LOAD_STATE_RESOLVING_HOST) { it->second.load_state = LOAD_STATE_CONNECTING; @@ -108,6 +87,7 @@ int TCPClientSocketPool::ConnectingSocket::OnIOCompleteInternal( } if (result == OK) { + CHECK(it->second.load_state == LOAD_STATE_CONNECTING); CHECK(connect_start_time_ != base::Time()); base::TimeDelta connect_duration = base::Time::Now() - connect_start_time_; @@ -141,17 +121,10 @@ int TCPClientSocketPool::ConnectingSocket::OnIOCompleteInternal( if (!synchronous) request.callback->Run(result); - delete this; + pool_->RemoveConnectingSocket(handle_); // will delete |this|. return result; } -void TCPClientSocketPool::ConnectingSocket::Cancel() { - CHECK(!canceled_); - CHECK(ContainsKey(pool_->connecting_socket_map_, handle_)); - pool_->connecting_socket_map_.erase(handle_); - canceled_ = true; -} - TCPClientSocketPool::TCPClientSocketPool( int max_sockets_per_group, HostResolver* host_resolver, @@ -168,6 +141,7 @@ TCPClientSocketPool::~TCPClientSocketPool() { // to the manager being destroyed. CloseIdleSockets(); DCHECK(group_map_.empty()); + DCHECK(connecting_socket_map_.empty()); } // InsertRequestIntoQueue inserts the request into the queue based on @@ -219,20 +193,16 @@ int TCPClientSocketPool::RequestSocket( // We couldn't find a socket to reuse, so allocate and connect a new one. - // First, we need to make sure we aren't already servicing a request for this - // handle (which could happen if we requested, canceled, and then requested - // with the same handle). - if (ContainsKey(connecting_socket_map_, handle)) - connecting_socket_map_[handle]->Cancel(); - CHECK(callback); Request r(handle, callback, priority, resolve_info, LOAD_STATE_RESOLVING_HOST); group_map_[group_name].connecting_requests[handle] = r; - // connecting_socket will delete itself. + CHECK(!ContainsKey(connecting_socket_map_, handle)); + ConnectingSocket* connecting_socket = new ConnectingSocket(group_name, handle, client_socket_factory_, this); + connecting_socket_map_[handle] = connecting_socket; int rv = connecting_socket->Connect(resolve_info); return rv; } @@ -257,6 +227,8 @@ void TCPClientSocketPool::CancelRequest(const std::string& group_name, RequestMap::iterator map_it = group.connecting_requests.find(handle); if (map_it != group.connecting_requests.end()) { + RemoveConnectingSocket(handle); + group.connecting_requests.erase(map_it); group.active_socket_count--; @@ -419,4 +391,12 @@ void TCPClientSocketPool::DoReleaseSocket(const std::string& group_name, } } +void TCPClientSocketPool::RemoveConnectingSocket( + const ClientSocketHandle* handle) { + ConnectingSocketMap::iterator it = connecting_socket_map_.find(handle); + CHECK(it != connecting_socket_map_.end()); + delete it->second; + connecting_socket_map_.erase(it); +} + } // namespace net diff --git a/net/base/tcp_client_socket_pool.h b/net/base/tcp_client_socket_pool.h index ad75585..33d2a5b 100644 --- a/net/base/tcp_client_socket_pool.h +++ b/net/base/tcp_client_socket_pool.h @@ -154,7 +154,6 @@ class TCPClientSocketPool : public ClientSocketPool { scoped_refptr<TCPClientSocketPool> pool_; SingleRequestHostResolver resolver_; AddressList addresses_; - bool canceled_; // The time the Connect() method was called (if it got called). base::Time connect_start_time_; @@ -162,6 +161,9 @@ class TCPClientSocketPool : public ClientSocketPool { DISALLOW_COPY_AND_ASSIGN(ConnectingSocket); }; + typedef std::map<const ClientSocketHandle*, ConnectingSocket*> + ConnectingSocketMap; + virtual ~TCPClientSocketPool(); static void InsertRequestIntoQueue(const Request& r, @@ -184,11 +186,15 @@ class TCPClientSocketPool : public ClientSocketPool { CleanupIdleSockets(false); } + // Removes the ConnectingSocket corresponding to |handle| from the + // |connecting_socket_map_|. + void RemoveConnectingSocket(const ClientSocketHandle* handle); + ClientSocketFactory* const client_socket_factory_; GroupMap group_map_; - std::map<const ClientSocketHandle*, ConnectingSocket*> connecting_socket_map_; + ConnectingSocketMap connecting_socket_map_; // Timer used to periodically prune idle sockets that timed out or can't be // reused. |