| Index: net/base/tcp_client_socket_unittest.cc
|
| ===================================================================
|
| --- net/base/tcp_client_socket_unittest.cc (revision 18948)
|
| +++ net/base/tcp_client_socket_unittest.cc (working copy)
|
| @@ -1,339 +0,0 @@
|
| -// Copyright (c) 2006-2009 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.
|
| -
|
| -#include "net/base/tcp_client_socket.h"
|
| -
|
| -#include "base/basictypes.h"
|
| -#include "net/base/address_list.h"
|
| -#include "net/base/host_resolver.h"
|
| -#include "net/base/io_buffer.h"
|
| -#include "net/base/listen_socket.h"
|
| -#include "net/base/net_errors.h"
|
| -#include "net/base/test_completion_callback.h"
|
| -#include "net/base/winsock_init.h"
|
| -#include "testing/gtest/include/gtest/gtest.h"
|
| -#include "testing/platform_test.h"
|
| -
|
| -namespace net {
|
| -
|
| -namespace {
|
| -
|
| -const char kServerReply[] = "HTTP/1.1 404 Not Found";
|
| -
|
| -class TCPClientSocketTest
|
| - : public PlatformTest, public ListenSocket::ListenSocketDelegate {
|
| - public:
|
| - TCPClientSocketTest() {
|
| - }
|
| -
|
| - // Implement ListenSocketDelegate methods
|
| - virtual void DidAccept(ListenSocket* server, ListenSocket* connection) {
|
| - connected_sock_ = connection;
|
| - }
|
| - virtual void DidRead(ListenSocket*, const std::string& s) {
|
| - // TODO(dkegel): this might not be long enough to tickle some bugs.
|
| - connected_sock_->Send(kServerReply,
|
| - arraysize(kServerReply) - 1,
|
| - false /* don't append line feed */);
|
| - }
|
| - virtual void DidClose(ListenSocket* sock) {}
|
| -
|
| - // Testcase hooks
|
| - virtual void SetUp();
|
| -
|
| - void CloseServerSocket() {
|
| - // delete the connected_sock_, which will close it.
|
| - connected_sock_ = NULL;
|
| - }
|
| -
|
| - void PauseServerReads() {
|
| - connected_sock_->PauseReads();
|
| - }
|
| -
|
| - void ResumeServerReads() {
|
| - connected_sock_->ResumeReads();
|
| - }
|
| -
|
| - protected:
|
| - int listen_port_;
|
| - scoped_ptr<TCPClientSocket> sock_;
|
| -
|
| - private:
|
| - scoped_refptr<ListenSocket> listen_sock_;
|
| - scoped_refptr<ListenSocket> connected_sock_;
|
| -};
|
| -
|
| -void TCPClientSocketTest::SetUp() {
|
| - PlatformTest::SetUp();
|
| -
|
| - // Find a free port to listen on
|
| - ListenSocket *sock = NULL;
|
| - int port;
|
| - // Range of ports to listen on. Shouldn't need to try many.
|
| - const int kMinPort = 10100;
|
| - const int kMaxPort = 10200;
|
| -#if defined(OS_WIN)
|
| - EnsureWinsockInit();
|
| -#endif
|
| - for (port = kMinPort; port < kMaxPort; port++) {
|
| - sock = ListenSocket::Listen("127.0.0.1", port, this);
|
| - if (sock)
|
| - break;
|
| - }
|
| - ASSERT_TRUE(sock != NULL);
|
| - listen_sock_ = sock;
|
| - listen_port_ = port;
|
| -
|
| - AddressList addr;
|
| - HostResolver resolver;
|
| - HostResolver::RequestInfo info("localhost", listen_port_);
|
| - int rv = resolver.Resolve(info, &addr, NULL, NULL);
|
| - CHECK(rv == OK);
|
| - sock_.reset(new TCPClientSocket(addr));
|
| -}
|
| -
|
| -TEST_F(TCPClientSocketTest, Connect) {
|
| - TestCompletionCallback callback;
|
| - EXPECT_FALSE(sock_->IsConnected());
|
| -
|
| - int rv = sock_->Connect(&callback);
|
| - if (rv != OK) {
|
| - ASSERT_EQ(rv, ERR_IO_PENDING);
|
| -
|
| - rv = callback.WaitForResult();
|
| - EXPECT_EQ(rv, OK);
|
| - }
|
| -
|
| - EXPECT_TRUE(sock_->IsConnected());
|
| -
|
| - sock_->Disconnect();
|
| - EXPECT_FALSE(sock_->IsConnected());
|
| -}
|
| -
|
| -// TODO(wtc): Add unit tests for IsConnectedAndIdle:
|
| -// - Server closes a connection.
|
| -// - Server sends data unexpectedly.
|
| -
|
| -TEST_F(TCPClientSocketTest, Read) {
|
| - TestCompletionCallback callback;
|
| - int rv = sock_->Connect(&callback);
|
| - if (rv != OK) {
|
| - ASSERT_EQ(rv, ERR_IO_PENDING);
|
| -
|
| - rv = callback.WaitForResult();
|
| - EXPECT_EQ(rv, OK);
|
| - }
|
| -
|
| - const char request_text[] = "GET / HTTP/1.0\r\n\r\n";
|
| - scoped_refptr<IOBuffer> request_buffer =
|
| - new IOBuffer(arraysize(request_text) - 1);
|
| - memcpy(request_buffer->data(), request_text, arraysize(request_text) - 1);
|
| -
|
| - rv = sock_->Write(request_buffer, arraysize(request_text) - 1, &callback);
|
| - EXPECT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
|
| -
|
| - if (rv == ERR_IO_PENDING) {
|
| - rv = callback.WaitForResult();
|
| - EXPECT_EQ(rv, static_cast<int>(arraysize(request_text) - 1));
|
| - }
|
| -
|
| - scoped_refptr<IOBuffer> buf = new IOBuffer(4096);
|
| - uint32 bytes_read = 0;
|
| - while (bytes_read < arraysize(kServerReply) - 1) {
|
| - rv = sock_->Read(buf, 4096, &callback);
|
| - EXPECT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
|
| -
|
| - if (rv == ERR_IO_PENDING)
|
| - rv = callback.WaitForResult();
|
| -
|
| - ASSERT_GE(rv, 0);
|
| - bytes_read += rv;
|
| - }
|
| -
|
| - // All data has been read now. Read once more to force an ERR_IO_PENDING, and
|
| - // then close the server socket, and note the close.
|
| -
|
| - rv = sock_->Read(buf, 4096, &callback);
|
| - ASSERT_EQ(ERR_IO_PENDING, rv);
|
| - CloseServerSocket();
|
| - EXPECT_EQ(0, callback.WaitForResult());
|
| -}
|
| -
|
| -TEST_F(TCPClientSocketTest, Read_SmallChunks) {
|
| - TestCompletionCallback callback;
|
| - int rv = sock_->Connect(&callback);
|
| - if (rv != OK) {
|
| - ASSERT_EQ(rv, ERR_IO_PENDING);
|
| -
|
| - rv = callback.WaitForResult();
|
| - EXPECT_EQ(rv, OK);
|
| - }
|
| -
|
| - const char request_text[] = "GET / HTTP/1.0\r\n\r\n";
|
| - scoped_refptr<IOBuffer> request_buffer =
|
| - new IOBuffer(arraysize(request_text) - 1);
|
| - memcpy(request_buffer->data(), request_text, arraysize(request_text) - 1);
|
| -
|
| - rv = sock_->Write(request_buffer, arraysize(request_text) - 1, &callback);
|
| - EXPECT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
|
| -
|
| - if (rv == ERR_IO_PENDING) {
|
| - rv = callback.WaitForResult();
|
| - EXPECT_EQ(rv, static_cast<int>(arraysize(request_text) - 1));
|
| - }
|
| -
|
| - scoped_refptr<IOBuffer> buf = new IOBuffer(1);
|
| - uint32 bytes_read = 0;
|
| - while (bytes_read < arraysize(kServerReply) - 1) {
|
| - rv = sock_->Read(buf, 1, &callback);
|
| - EXPECT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
|
| -
|
| - if (rv == ERR_IO_PENDING)
|
| - rv = callback.WaitForResult();
|
| -
|
| - ASSERT_EQ(1, rv);
|
| - bytes_read += rv;
|
| - }
|
| -
|
| - // All data has been read now. Read once more to force an ERR_IO_PENDING, and
|
| - // then close the server socket, and note the close.
|
| -
|
| - rv = sock_->Read(buf, 1, &callback);
|
| - ASSERT_EQ(ERR_IO_PENDING, rv);
|
| - CloseServerSocket();
|
| - EXPECT_EQ(0, callback.WaitForResult());
|
| -}
|
| -
|
| -TEST_F(TCPClientSocketTest, Read_Interrupted) {
|
| - TestCompletionCallback callback;
|
| - int rv = sock_->Connect(&callback);
|
| - if (rv != OK) {
|
| - ASSERT_EQ(ERR_IO_PENDING, rv);
|
| -
|
| - rv = callback.WaitForResult();
|
| - EXPECT_EQ(rv, OK);
|
| - }
|
| -
|
| - const char request_text[] = "GET / HTTP/1.0\r\n\r\n";
|
| - scoped_refptr<IOBuffer> request_buffer =
|
| - new IOBuffer(arraysize(request_text) - 1);
|
| - memcpy(request_buffer->data(), request_text, arraysize(request_text) - 1);
|
| -
|
| - rv = sock_->Write(request_buffer, arraysize(request_text) - 1, &callback);
|
| - EXPECT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
|
| -
|
| - if (rv == ERR_IO_PENDING) {
|
| - rv = callback.WaitForResult();
|
| - EXPECT_EQ(rv, static_cast<int>(arraysize(request_text) - 1));
|
| - }
|
| -
|
| - // Do a partial read and then exit. This test should not crash!
|
| - scoped_refptr<IOBuffer> buf = new IOBuffer(16);
|
| - rv = sock_->Read(buf, 16, &callback);
|
| - EXPECT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
|
| -
|
| - if (rv == ERR_IO_PENDING)
|
| - rv = callback.WaitForResult();
|
| -
|
| - EXPECT_NE(0, rv);
|
| -}
|
| -
|
| -TEST_F(TCPClientSocketTest, DISABLED_FullDuplex_ReadFirst) {
|
| - TestCompletionCallback callback;
|
| - int rv = sock_->Connect(&callback);
|
| - if (rv != OK) {
|
| - ASSERT_EQ(rv, ERR_IO_PENDING);
|
| -
|
| - rv = callback.WaitForResult();
|
| - EXPECT_EQ(rv, OK);
|
| - }
|
| -
|
| - // Read first. There's no data, so it should return ERR_IO_PENDING.
|
| - const int kBufLen = 4096;
|
| - scoped_refptr<IOBuffer> buf = new IOBuffer(kBufLen);
|
| - rv = sock_->Read(buf, kBufLen, &callback);
|
| - EXPECT_EQ(ERR_IO_PENDING, rv);
|
| -
|
| - PauseServerReads();
|
| - const int kWriteBufLen = 64 * 1024;
|
| - scoped_refptr<IOBuffer> request_buffer = new IOBuffer(kWriteBufLen);
|
| - char* request_data = request_buffer->data();
|
| - memset(request_data, 'A', kWriteBufLen);
|
| - TestCompletionCallback write_callback;
|
| -
|
| - while (true) {
|
| - rv = sock_->Write(request_buffer, kWriteBufLen, &write_callback);
|
| - ASSERT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
|
| -
|
| - if (rv == ERR_IO_PENDING) {
|
| - ResumeServerReads();
|
| - rv = write_callback.WaitForResult();
|
| - break;
|
| - }
|
| - }
|
| -
|
| - // At this point, both read and write have returned ERR_IO_PENDING, and the
|
| - // write callback has executed. We wait for the read callback to run now to
|
| - // make sure that the socket can handle full duplex communications.
|
| -
|
| - rv = callback.WaitForResult();
|
| - EXPECT_GE(rv, 0);
|
| -}
|
| -
|
| -TEST_F(TCPClientSocketTest, DISABLED_FullDuplex_WriteFirst) {
|
| - TestCompletionCallback callback;
|
| - int rv = sock_->Connect(&callback);
|
| - if (rv != OK) {
|
| - ASSERT_EQ(ERR_IO_PENDING, rv);
|
| -
|
| - rv = callback.WaitForResult();
|
| - EXPECT_EQ(OK, rv);
|
| - }
|
| -
|
| - PauseServerReads();
|
| - const int kWriteBufLen = 64 * 1024;
|
| - scoped_refptr<IOBuffer> request_buffer = new IOBuffer(kWriteBufLen);
|
| - char* request_data = request_buffer->data();
|
| - memset(request_data, 'A', kWriteBufLen);
|
| - TestCompletionCallback write_callback;
|
| -
|
| - while (true) {
|
| - rv = sock_->Write(request_buffer, kWriteBufLen, &write_callback);
|
| - ASSERT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
|
| -
|
| - if (rv == ERR_IO_PENDING)
|
| - break;
|
| - }
|
| -
|
| - // Now we have the Write() blocked on ERR_IO_PENDING. It's time to force the
|
| - // Read() to block on ERR_IO_PENDING too.
|
| -
|
| - const int kBufLen = 4096;
|
| - scoped_refptr<IOBuffer> buf = new IOBuffer(kBufLen);
|
| - while (true) {
|
| - rv = sock_->Read(buf, kBufLen, &callback);
|
| - ASSERT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
|
| - if (rv == ERR_IO_PENDING)
|
| - break;
|
| - }
|
| -
|
| - // At this point, both read and write have returned ERR_IO_PENDING. Now we
|
| - // run the write and read callbacks to make sure they can handle full duplex
|
| - // communications.
|
| -
|
| - ResumeServerReads();
|
| - rv = write_callback.WaitForResult();
|
| - EXPECT_GE(rv, 0);
|
| -
|
| - // It's possible the read is blocked because it's already read all the data.
|
| - // Close the server socket, so there will at least be a 0-byte read.
|
| - CloseServerSocket();
|
| -
|
| - rv = callback.WaitForResult();
|
| - EXPECT_GE(rv, 0);
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -} // namespace net
|
|
|