diff options
author | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-01 14:54:21 +0000 |
---|---|---|
committer | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-01 14:54:21 +0000 |
commit | 464513520a7792134dd0fa5a939f99128d4890ba (patch) | |
tree | 6c8db80f83be5329b2d5c0db962d824a410e517d | |
parent | c6d884ac6059305e721c2eedbf6ce95e5459bf86 (diff) | |
download | chromium_src-464513520a7792134dd0fa5a939f99128d4890ba.zip chromium_src-464513520a7792134dd0fa5a939f99128d4890ba.tar.gz chromium_src-464513520a7792134dd0fa5a939f99128d4890ba.tar.bz2 |
Make GetLoadState virtual in ConnectJob().
This will be necessary for SSLClientSocketPool since the SSLConnectJob will contain a ClientSocketHandle for the TCPClientSocketPool. SSLConnectJob::GetLoadState() will forward to ClientSocketHandle::GetLoadState() if the SSLConnectJob is waiting on requesting a TCP socket.
BUG=http://crbug.com/13289.
Review URL: http://codereview.chromium.org/176024
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@25032 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | net/socket/client_socket_pool_base.cc | 5 | ||||
-rw-r--r-- | net/socket/client_socket_pool_base.h | 6 | ||||
-rw-r--r-- | net/socket/client_socket_pool_base_unittest.cc | 10 | ||||
-rw-r--r-- | net/socket/tcp_client_socket_pool.cc | 18 | ||||
-rw-r--r-- | net/socket/tcp_client_socket_pool.h | 1 |
5 files changed, 27 insertions, 13 deletions
diff --git a/net/socket/client_socket_pool_base.cc b/net/socket/client_socket_pool_base.cc index 18a084b..1dc1180 100644 --- a/net/socket/client_socket_pool_base.cc +++ b/net/socket/client_socket_pool_base.cc @@ -37,7 +37,6 @@ ConnectJob::ConnectJob(const std::string& group_name, key_handle_(key_handle), timeout_duration_(timeout_duration), delegate_(delegate), - load_state_(LOAD_STATE_IDLE), load_log_(load_log) { DCHECK(!group_name.empty()); DCHECK(key_handle); @@ -314,7 +313,7 @@ LoadState ClientSocketPoolBaseHelper::GetLoadState( NOTREACHED(); return LOAD_STATE_IDLE; } - return job_it->second->load_state(); + return job_it->second->GetLoadState(); } // Search pending_requests for matching handle. @@ -325,7 +324,7 @@ LoadState ClientSocketPoolBaseHelper::GetLoadState( LoadState max_state = LOAD_STATE_IDLE; for (ConnectJobSet::const_iterator job_it = group.jobs.begin(); job_it != group.jobs.end(); ++job_it) { - max_state = std::max(max_state, (*job_it)->load_state()); + max_state = std::max(max_state, (*job_it)->GetLoadState()); } return max_state; } else { diff --git a/net/socket/client_socket_pool_base.h b/net/socket/client_socket_pool_base.h index 4b5a3b1..23c194c 100644 --- a/net/socket/client_socket_pool_base.h +++ b/net/socket/client_socket_pool_base.h @@ -70,8 +70,8 @@ class ConnectJob { // Accessors const std::string& group_name() const { return group_name_; } - LoadState load_state() const { return load_state_; } const ClientSocketHandle* key_handle() const { return key_handle_; } + LoadLog* load_log() { return load_log_; } // Releases |socket_| to the client. On connection error, this should return // NULL. @@ -85,10 +85,9 @@ class ConnectJob { // if it succeeded. int Connect(); - LoadLog* load_log() { return load_log_; } + virtual LoadState GetLoadState() const = 0; protected: - void set_load_state(LoadState load_state) { load_state_ = load_state; } void set_socket(ClientSocket* socket) { socket_.reset(socket); } ClientSocket* socket() { return socket_.get(); } void NotifyDelegateOfCompletion(int rv); @@ -106,7 +105,6 @@ class ConnectJob { // Timer to abort jobs that take too long. base::OneShotTimer<ConnectJob> timer_; Delegate* delegate_; - LoadState load_state_; scoped_ptr<ClientSocket> socket_; scoped_refptr<LoadLog> load_log_; diff --git a/net/socket/client_socket_pool_base_unittest.cc b/net/socket/client_socket_pool_base_unittest.cc index 020bc98..970b0ba 100644 --- a/net/socket/client_socket_pool_base_unittest.cc +++ b/net/socket/client_socket_pool_base_unittest.cc @@ -118,12 +118,15 @@ class TestConnectJob : public ConnectJob { delegate, load_log), job_type_(job_type), client_socket_factory_(client_socket_factory), - method_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)) {} + method_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)), + load_state_(LOAD_STATE_IDLE) {} void Signal() { DoConnect(waiting_success_, true /* async */); } + virtual LoadState GetLoadState() const { return load_state_; } + private: // ConnectJob methods: @@ -162,7 +165,7 @@ class TestConnectJob : public ConnectJob { MessageLoop::current()->PostTask( FROM_HERE, method_factory_.NewRunnableMethod( - &TestConnectJob::AdvanceLoadState, load_state())); + &TestConnectJob::AdvanceLoadState, load_state_)); return ERR_IO_PENDING; default: NOTREACHED(); @@ -171,6 +174,8 @@ class TestConnectJob : public ConnectJob { } } + void set_load_state(LoadState load_state) { load_state_ = load_state; } + int DoConnect(bool succeed, bool was_async) { int result = ERR_CONNECTION_FAILED; if (succeed) { @@ -202,6 +207,7 @@ class TestConnectJob : public ConnectJob { const JobType job_type_; MockClientSocketFactory* const client_socket_factory_; ScopedRunnableMethodFactory<TestConnectJob> method_factory_; + LoadState load_state_; DISALLOW_COPY_AND_ASSIGN(TestConnectJob); }; diff --git a/net/socket/tcp_client_socket_pool.cc b/net/socket/tcp_client_socket_pool.cc index 8a5c4d3..d73221a 100644 --- a/net/socket/tcp_client_socket_pool.cc +++ b/net/socket/tcp_client_socket_pool.cc @@ -44,6 +44,20 @@ TCPConnectJob::~TCPConnectJob() { // ~SingleRequestHostResolver and ~ClientSocket will take care of it. } +LoadState TCPConnectJob::GetLoadState() const { + switch (next_state_) { + case kStateResolveHost: + case kStateResolveHostComplete: + return LOAD_STATE_RESOLVING_HOST; + case kStateTCPConnect: + case kStateTCPConnectComplete: + return LOAD_STATE_CONNECTING; + default: + NOTREACHED(); + return LOAD_STATE_IDLE; + } +} + int TCPConnectJob::ConnectInternal() { next_state_ = kStateResolveHost; return DoLoop(OK); @@ -88,13 +102,11 @@ int TCPConnectJob::DoLoop(int result) { } int TCPConnectJob::DoResolveHost() { - set_load_state(LOAD_STATE_RESOLVING_HOST); next_state_ = kStateResolveHostComplete; return resolver_.Resolve(resolve_info_, &addresses_, &callback_, load_log()); } int TCPConnectJob::DoResolveHostComplete(int result) { - DCHECK_EQ(LOAD_STATE_RESOLVING_HOST, load_state()); if (result == OK) next_state_ = kStateTCPConnect; return result; @@ -102,7 +114,6 @@ int TCPConnectJob::DoResolveHostComplete(int result) { int TCPConnectJob::DoTCPConnect() { next_state_ = kStateTCPConnectComplete; - set_load_state(LOAD_STATE_CONNECTING); set_socket(client_socket_factory_->CreateTCPClientSocket(addresses_)); connect_start_time_ = base::TimeTicks::Now(); // TODO(eroman): Socket::Connect() should take a LoadLog. @@ -110,7 +121,6 @@ int TCPConnectJob::DoTCPConnect() { } int TCPConnectJob::DoTCPConnectComplete(int result) { - DCHECK_EQ(load_state(), LOAD_STATE_CONNECTING); if (result == OK) { DCHECK(connect_start_time_ != base::TimeTicks()); base::TimeDelta connect_duration = diff --git a/net/socket/tcp_client_socket_pool.h b/net/socket/tcp_client_socket_pool.h index 03d9178..8a3d1f7 100644 --- a/net/socket/tcp_client_socket_pool.h +++ b/net/socket/tcp_client_socket_pool.h @@ -35,6 +35,7 @@ class TCPConnectJob : public ConnectJob { virtual ~TCPConnectJob(); // ConnectJob methods. + virtual LoadState GetLoadState() const; private: enum State { |