diff options
author | wtc@google.com <wtc@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-05 00:15:45 +0000 |
---|---|---|
committer | wtc@google.com <wtc@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-05 00:15:45 +0000 |
commit | 7b822b2be3e9eff10ffb9065f2449678fc0aab59 (patch) | |
tree | 327115bd0d34676b82470838697133ae54b3f97f /net/http | |
parent | d5af37154930195aa20ca0f6346f5c5f4bb54eda (diff) | |
download | chromium_src-7b822b2be3e9eff10ffb9065f2449678fc0aab59.zip chromium_src-7b822b2be3e9eff10ffb9065f2449678fc0aab59.tar.gz chromium_src-7b822b2be3e9eff10ffb9065f2449678fc0aab59.tar.bz2 |
Miscellaneous changes (mostly cleanup) from my code review.
R=darin@google.com
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@354 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/http')
-rw-r--r-- | net/http/http_chunked_decoder_unittest.cc | 9 | ||||
-rw-r--r-- | net/http/http_connection.h | 13 | ||||
-rw-r--r-- | net/http/http_connection_manager.cc | 39 | ||||
-rw-r--r-- | net/http/http_connection_manager.h | 16 | ||||
-rw-r--r-- | net/http/http_connection_manager_unittest.cc | 6 | ||||
-rw-r--r-- | net/http/http_network_layer.h | 6 |
6 files changed, 52 insertions, 37 deletions
diff --git a/net/http/http_chunked_decoder_unittest.cc b/net/http/http_chunked_decoder_unittest.cc index 602ba6a..377f1b1 100644 --- a/net/http/http_chunked_decoder_unittest.cc +++ b/net/http/http_chunked_decoder_unittest.cc @@ -46,7 +46,7 @@ void RunTest(const char* inputs[], size_t num_inputs, for (size_t i = 0; i < num_inputs; ++i) { std::string input = inputs[i]; int n = decoder.FilterBuf(&input[0], static_cast<int>(input.size())); - EXPECT_TRUE(n >= 0); + EXPECT_GE(n, 0); if (n > 0) result.append(input.data(), n); } @@ -64,6 +64,13 @@ TEST(HttpChunkedDecoderTest, Basic) { RunTest(inputs, arraysize(inputs), "hello", true); } +TEST(HttpChunkedDecoderTest, OneChunk) { + const char* inputs[] = { + "5\r\nhello\r\n" + }; + RunTest(inputs, arraysize(inputs), "hello", false); +} + TEST(HttpChunkedDecoderTest, Typical) { const char* inputs[] = { "5\r\nhello\r\n", diff --git a/net/http/http_connection.h b/net/http/http_connection.h index ada8468..e3a6496 100644 --- a/net/http/http_connection.h +++ b/net/http/http_connection.h @@ -30,6 +30,8 @@ #ifndef NET_HTTP_HTTP_CONNECTION_H_ #define NET_HTTP_HTTP_CONNECTION_H_ +#include <string> + #include "base/ref_counted.h" #include "base/scoped_ptr.h" #include "net/base/client_socket.h" @@ -50,11 +52,12 @@ class HttpConnectionManager; // class HttpConnection { public: - HttpConnection(HttpConnectionManager* mgr); + explicit HttpConnection(HttpConnectionManager* mgr); ~HttpConnection(); // Initializes a HttpConnection object, which involves talking to the - // HttpConnectionManager to locate a socket to possibly reuse. + // HttpConnectionManager to locate a socket to possibly reuse. This method + // returns either OK or ERR_IO_PENDING. // // If this method succeeds, then the socket member will be set to an existing // socket if an existing socket was available to reuse. Otherwise, the @@ -69,9 +72,9 @@ class HttpConnection { // An initialized connection can be reset, which causes it to return to the // un-initialized state. This releases the underlying socket, which in the - // case of a socket that is not closed, indicates that the socket may be kept - // alive for use by a subsequent HttpConnection. NOTE: To prevent the socket - // from being kept alive, be sure to call its Close method. + // case of a socket that is not disconnected, indicates that the socket may + // be kept alive for use by a subsequent HttpConnection. NOTE: To prevent + // the socket from being kept alive, be sure to call its Disconnect method. void Reset(); // Returns true when Init has completed successfully. diff --git a/net/http/http_connection_manager.cc b/net/http/http_connection_manager.cc index a7edd92..7064c4f 100644 --- a/net/http/http_connection_manager.cc +++ b/net/http/http_connection_manager.cc @@ -33,18 +33,25 @@ #include "net/base/client_socket.h" #include "net/base/net_errors.h" +namespace { + +// The timeout value, in seconds, used to clean up disconnected idle sockets. +const int kCleanupInterval = 5; + +} // namespace + namespace net { HttpConnectionManager::HttpConnectionManager() - : timer_(TimeDelta::FromSeconds(5)), - idle_count_(0) { + : timer_(TimeDelta::FromSeconds(kCleanupInterval)), + idle_socket_count_(0) { timer_.set_task(this); } HttpConnectionManager::~HttpConnectionManager() { timer_.set_task(NULL); - // Cleanup any idle sockets. Assert that we have no remaining active sockets + // Clean up any idle sockets. Assert that we have no remaining active sockets // or pending requests. They should have all been cleaned up prior to the // manager being destroyed. @@ -55,13 +62,13 @@ HttpConnectionManager::~HttpConnectionManager() { int HttpConnectionManager::RequestSocket(const std::string& group_name, SocketHandle** handle, CompletionCallback* callback) { - Group& group = - group_map_.insert(std::make_pair(group_name, Group())).first->second; + Group& group = group_map_[group_name]; // Can we make another active socket now? if (group.active_socket_count == kMaxSocketsPerGroup) { Request r; r.result = handle; + DCHECK(callback); r.callback = callback; group.pending_requests.push_back(r); return ERR_IO_PENDING; @@ -70,18 +77,18 @@ int HttpConnectionManager::RequestSocket(const std::string& group_name, // OK, we are going to activate one. group.active_socket_count++; - // Use idle sockets in LIFO order. + // Use idle sockets in LIFO order because they're more likely to be + // still connected. while (!group.idle_sockets.empty()) { SocketHandle* h = group.idle_sockets.back(); group.idle_sockets.pop_back(); DecrementIdleCount(); - if (!h->get()->IsConnected()) { - delete h; - } else { + if (h->get()->IsConnected()) { // We found one we can reuse! *handle = h; return OK; } + delete h; } *handle = new SocketHandle(); @@ -93,7 +100,8 @@ void HttpConnectionManager::CancelRequest(const std::string& group_name, Group& group = group_map_[group_name]; // In order for us to be canceling a pending request, we must have active - // sockets equaling the limit. + // sockets equaling the limit. NOTE: The correctness of the code doesn't + // require this assertion. DCHECK(group.active_socket_count == kMaxSocketsPerGroup); // Search pending_requests for matching handle. @@ -120,7 +128,7 @@ void HttpConnectionManager::CloseIdleSockets() { void HttpConnectionManager::MaybeCloseIdleSockets( bool only_if_disconnected) { - if (idle_count_ == 0) + if (idle_socket_count_ == 0) return; GroupMap::iterator i = group_map_.begin(); @@ -149,12 +157,12 @@ void HttpConnectionManager::MaybeCloseIdleSockets( } void HttpConnectionManager::IncrementIdleCount() { - if (++idle_count_ == 1) + if (++idle_socket_count_ == 1) timer_.Start(); } void HttpConnectionManager::DecrementIdleCount() { - if (--idle_count_ == 0) + if (--idle_socket_count_ == 0) timer_.Stop(); } @@ -180,8 +188,9 @@ void HttpConnectionManager::DoReleaseSocket(const std::string& group_name, if (!group.pending_requests.empty()) { Request r = group.pending_requests.front(); group.pending_requests.pop_front(); - RequestSocket(i->first, r.result, NULL); - r.callback->Run(OK); + int rv = RequestSocket(i->first, r.result, NULL); + DCHECK(rv == OK); + r.callback->Run(rv); return; } diff --git a/net/http/http_connection_manager.h b/net/http/http_connection_manager.h index 22080a3..fc5402c 100644 --- a/net/http/http_connection_manager.h +++ b/net/http/http_connection_manager.h @@ -32,6 +32,7 @@ #include <deque> #include <map> +#include <string> #include "base/ref_counted.h" #include "base/timer.h" @@ -45,7 +46,7 @@ class ClientSocket; // open at a time. It also maintains a list of idle persistent sockets. // // The HttpConnectionManager allocates SocketHandle objects, but it is not -// responsible for allocating the associated ClientSocket object. The +// responsible for allocating the associated ClientSocket objects. The // consumer must do so if it gets a SocketHandle with a null ClientSocket. // class HttpConnectionManager : public base::RefCounted<HttpConnectionManager>, @@ -62,11 +63,10 @@ class HttpConnectionManager : public base::RefCounted<HttpConnectionManager>, // // If this function returns OK, then |*handle| will reference a SocketHandle // object. If ERR_IO_PENDING is returned, then the completion callback will - // be called when |*handle| has been populated. Otherwise, an error code is - // returned. + // be called when |*handle| has been populated. // // If the resultant SocketHandle object has a null member, then it is the - // callers job to create a ClientSocket and associate it with the handle. + // caller's job to create a ClientSocket and associate it with the handle. // int RequestSocket(const std::string& group_name, SocketHandle** handle, CompletionCallback* callback); @@ -91,7 +91,9 @@ class HttpConnectionManager : public base::RefCounted<HttpConnectionManager>, ~HttpConnectionManager(); // Closes all idle sockets if |only_if_disconnected| is false. Else, only - // idle sockets that are disconnected get closed. + // idle sockets that are disconnected get closed. "Maybe" refers to the + // fact that it doesn't close all idle sockets if |only_if_disconnected| is + // true. void MaybeCloseIdleSockets(bool only_if_disconnected); // Called when the number of idle sockets changes. @@ -115,10 +117,10 @@ class HttpConnectionManager : public base::RefCounted<HttpConnectionManager>, // A Group is allocated per group_name when there are idle sockets or pending // requests. Otherwise, the Group object is removed from the map. struct Group { + Group() : active_socket_count(0) {} std::deque<SocketHandle*> idle_sockets; std::deque<Request> pending_requests; int active_socket_count; - Group() : active_socket_count(0) {} }; typedef std::map<std::string, Group> GroupMap; @@ -128,7 +130,7 @@ class HttpConnectionManager : public base::RefCounted<HttpConnectionManager>, RepeatingTimer timer_; // The total number of idle sockets in the system. - int idle_count_; + int idle_socket_count_; }; } // namespace net diff --git a/net/http/http_connection_manager_unittest.cc b/net/http/http_connection_manager_unittest.cc index 9eade18..503097b 100644 --- a/net/http/http_connection_manager_unittest.cc +++ b/net/http/http_connection_manager_unittest.cc @@ -67,12 +67,6 @@ class MockClientSocket : public net::ClientSocket { net::CompletionCallback* callback) { return net::ERR_FAILED; } - virtual int GetProperty(int property, void* buf, int buf_len) const { - return net::ERR_FAILED; - } - virtual int SetProperty(int property, const void* buf, int buf_len) { - return net::ERR_FAILED; - } static int allocation_count; diff --git a/net/http/http_network_layer.h b/net/http/http_network_layer.h index 72fbca3..db7d0d9 100644 --- a/net/http/http_network_layer.h +++ b/net/http/http_network_layer.h @@ -40,6 +40,9 @@ class HttpProxyInfo; class HttpNetworkLayer : public HttpTransactionFactory { public: + explicit HttpNetworkLayer(const HttpProxyInfo* pi); + ~HttpNetworkLayer(); + // This function hides the details of how a network layer gets instantiated // and allows other implementations to be substituted. static HttpTransactionFactory* CreateFactory(const HttpProxyInfo* pi); @@ -47,9 +50,6 @@ class HttpNetworkLayer : public HttpTransactionFactory { // If value is true, then WinHTTP will be used. static void UseWinHttp(bool value); - HttpNetworkLayer(const HttpProxyInfo* pi); - ~HttpNetworkLayer(); - // HttpTransactionFactory methods: virtual HttpTransaction* CreateTransaction(); virtual HttpCache* GetCache(); |