Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(638)

Unified Diff: net/socket/transport_client_socket_unittest.cc

Issue 1053343002: Use TCPServerSocket instead of TCPListenSocket in transport_client_socket_unittest.cc (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Moved tests to tcp_client_socket_unittests.cc Created 5 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: net/socket/transport_client_socket_unittest.cc
diff --git a/net/socket/transport_client_socket_unittest.cc b/net/socket/transport_client_socket_unittest.cc
deleted file mode 100644
index 0073a1b35988a06159e29cf9a8f9bf8d9837b11a..0000000000000000000000000000000000000000
--- a/net/socket/transport_client_socket_unittest.cc
+++ /dev/null
@@ -1,450 +0,0 @@
-// 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.
-
-#include "net/socket/tcp_client_socket.h"
-
-#include "base/basictypes.h"
-#include "base/memory/ref_counted.h"
-#include "base/memory/scoped_ptr.h"
-#include "net/base/address_list.h"
-#include "net/base/io_buffer.h"
-#include "net/base/net_errors.h"
-#include "net/base/test_completion_callback.h"
-#include "net/base/winsock_init.h"
-#include "net/dns/mock_host_resolver.h"
-#include "net/log/net_log.h"
-#include "net/log/net_log_unittest.h"
-#include "net/socket/client_socket_factory.h"
-#include "net/socket/tcp_listen_socket.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";
-
-enum ClientSocketTestTypes {
- TCP,
- SCTP
-};
-
-} // namespace
-
-class TransportClientSocketTest
- : public StreamListenSocket::Delegate,
- public ::testing::TestWithParam<ClientSocketTestTypes> {
- public:
- TransportClientSocketTest()
- : listen_port_(0),
- socket_factory_(ClientSocketFactory::GetDefaultFactory()),
- close_server_socket_on_next_send_(false) {
- }
-
- virtual ~TransportClientSocketTest() {
- }
-
- // Implement StreamListenSocket::Delegate methods
- void DidAccept(StreamListenSocket* server,
- scoped_ptr<StreamListenSocket> connection) override {
- connected_sock_.reset(
- static_cast<TCPListenSocket*>(connection.release()));
- }
- void DidRead(StreamListenSocket*, const char* str, int len) override {
- // 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 */);
- if (close_server_socket_on_next_send_)
- CloseServerSocket();
- }
- void DidClose(StreamListenSocket* sock) override {}
-
- // Testcase hooks
- void SetUp() override;
-
- void CloseServerSocket() {
- // delete the connected_sock_, which will close it.
- connected_sock_.reset();
- }
-
- void PauseServerReads() {
- connected_sock_->PauseReads();
- }
-
- void ResumeServerReads() {
- connected_sock_->ResumeReads();
- }
-
- int DrainClientSocket(IOBuffer* buf,
- uint32 buf_len,
- uint32 bytes_to_read,
- TestCompletionCallback* callback);
-
- void SendClientRequest();
-
- void set_close_server_socket_on_next_send(bool close) {
- close_server_socket_on_next_send_ = close;
- }
-
- protected:
- uint16 listen_port_;
- TestNetLog net_log_;
- ClientSocketFactory* const socket_factory_;
- scoped_ptr<StreamSocket> sock_;
-
- private:
- scoped_ptr<TCPListenSocket> listen_sock_;
- scoped_ptr<TCPListenSocket> connected_sock_;
- bool close_server_socket_on_next_send_;
-};
-
-void TransportClientSocketTest::SetUp() {
- ::testing::TestWithParam<ClientSocketTestTypes>::SetUp();
-
- // Find a free port to listen on
- scoped_ptr<TCPListenSocket> sock;
- uint16 port;
- // Range of ports to listen on. Shouldn't need to try many.
- const uint16 kMinPort = 10100;
- const uint16 kMaxPort = 10200;
-#if defined(OS_WIN)
- EnsureWinsockInit();
-#endif
- for (port = kMinPort; port < kMaxPort; port++) {
- sock = TCPListenSocket::CreateAndListen("127.0.0.1", port, this);
- if (sock.get())
- break;
- }
- ASSERT_TRUE(sock.get() != NULL);
- listen_sock_ = sock.Pass();
- listen_port_ = port;
-
- AddressList addr;
- // MockHostResolver resolves everything to 127.0.0.1.
- scoped_ptr<HostResolver> resolver(new MockHostResolver());
- HostResolver::RequestInfo info(HostPortPair("localhost", listen_port_));
- TestCompletionCallback callback;
- int rv = resolver->Resolve(
- info, DEFAULT_PRIORITY, &addr, callback.callback(), NULL, BoundNetLog());
- CHECK_EQ(ERR_IO_PENDING, rv);
- rv = callback.WaitForResult();
- CHECK_EQ(rv, OK);
- sock_ =
- socket_factory_->CreateTransportClientSocket(addr,
- &net_log_,
- NetLog::Source());
-}
-
-int TransportClientSocketTest::DrainClientSocket(
- IOBuffer* buf, uint32 buf_len,
- uint32 bytes_to_read, TestCompletionCallback* callback) {
- int rv = OK;
- uint32 bytes_read = 0;
-
- while (bytes_read < bytes_to_read) {
- rv = sock_->Read(buf, buf_len, callback->callback());
- EXPECT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
-
- if (rv == ERR_IO_PENDING)
- rv = callback->WaitForResult();
-
- EXPECT_GE(rv, 0);
- bytes_read += rv;
- }
-
- return static_cast<int>(bytes_read);
-}
-
-void TransportClientSocketTest::SendClientRequest() {
- const char request_text[] = "GET / HTTP/1.0\r\n\r\n";
- scoped_refptr<IOBuffer> request_buffer(
- new IOBuffer(arraysize(request_text) - 1));
- TestCompletionCallback callback;
- int rv;
-
- memcpy(request_buffer->data(), request_text, arraysize(request_text) - 1);
- rv = sock_->Write(
- request_buffer.get(), arraysize(request_text) - 1, callback.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));
-}
-
-// TODO(leighton): Add SCTP to this list when it is ready.
-INSTANTIATE_TEST_CASE_P(StreamSocket,
- TransportClientSocketTest,
- ::testing::Values(TCP));
-
-TEST_P(TransportClientSocketTest, Connect) {
- TestCompletionCallback callback;
- EXPECT_FALSE(sock_->IsConnected());
-
- int rv = sock_->Connect(callback.callback());
-
- TestNetLog::CapturedEntryList net_log_entries;
- net_log_.GetEntries(&net_log_entries);
- EXPECT_TRUE(
- LogContainsBeginEvent(net_log_entries, 0, NetLog::TYPE_SOCKET_ALIVE));
- EXPECT_TRUE(
- LogContainsBeginEvent(net_log_entries, 1, NetLog::TYPE_TCP_CONNECT));
- if (rv != OK) {
- ASSERT_EQ(rv, ERR_IO_PENDING);
- rv = callback.WaitForResult();
- EXPECT_EQ(rv, OK);
- }
-
- EXPECT_TRUE(sock_->IsConnected());
- net_log_.GetEntries(&net_log_entries);
- EXPECT_TRUE(
- LogContainsEndEvent(net_log_entries, -1, NetLog::TYPE_TCP_CONNECT));
-
- sock_->Disconnect();
- EXPECT_FALSE(sock_->IsConnected());
-}
-
-TEST_P(TransportClientSocketTest, IsConnected) {
- scoped_refptr<IOBuffer> buf(new IOBuffer(4096));
- TestCompletionCallback callback;
- uint32 bytes_read;
-
- EXPECT_FALSE(sock_->IsConnected());
- EXPECT_FALSE(sock_->IsConnectedAndIdle());
- int rv = sock_->Connect(callback.callback());
- if (rv != OK) {
- ASSERT_EQ(rv, ERR_IO_PENDING);
- rv = callback.WaitForResult();
- EXPECT_EQ(rv, OK);
- }
- EXPECT_TRUE(sock_->IsConnected());
- EXPECT_TRUE(sock_->IsConnectedAndIdle());
-
- // Send the request and wait for the server to respond.
- SendClientRequest();
-
- // Drain a single byte so we know we've received some data.
- bytes_read = DrainClientSocket(buf.get(), 1, 1, &callback);
- ASSERT_EQ(bytes_read, 1u);
-
- // Socket should be considered connected, but not idle, due to
- // pending data.
- EXPECT_TRUE(sock_->IsConnected());
- EXPECT_FALSE(sock_->IsConnectedAndIdle());
-
- bytes_read = DrainClientSocket(
- buf.get(), 4096, arraysize(kServerReply) - 2, &callback);
- ASSERT_EQ(bytes_read, arraysize(kServerReply) - 2);
-
- // After draining the data, the socket should be back to connected
- // and idle.
- EXPECT_TRUE(sock_->IsConnected());
- EXPECT_TRUE(sock_->IsConnectedAndIdle());
-
- // This time close the server socket immediately after the server response.
- set_close_server_socket_on_next_send(true);
- SendClientRequest();
-
- bytes_read = DrainClientSocket(buf.get(), 1, 1, &callback);
- ASSERT_EQ(bytes_read, 1u);
-
- // As above because of data.
- EXPECT_TRUE(sock_->IsConnected());
- EXPECT_FALSE(sock_->IsConnectedAndIdle());
-
- bytes_read = DrainClientSocket(
- buf.get(), 4096, arraysize(kServerReply) - 2, &callback);
- ASSERT_EQ(bytes_read, arraysize(kServerReply) - 2);
-
- // Once the data is drained, the socket should now be seen as not
- // connected.
- if (sock_->IsConnected()) {
- // In the unlikely event that the server's connection closure is not
- // processed in time, wait for the connection to be closed.
- rv = sock_->Read(buf.get(), 4096, callback.callback());
- EXPECT_EQ(0, callback.GetResult(rv));
- EXPECT_FALSE(sock_->IsConnected());
- }
- EXPECT_FALSE(sock_->IsConnectedAndIdle());
-}
-
-TEST_P(TransportClientSocketTest, Read) {
- TestCompletionCallback callback;
- int rv = sock_->Connect(callback.callback());
- if (rv != OK) {
- ASSERT_EQ(rv, ERR_IO_PENDING);
-
- rv = callback.WaitForResult();
- EXPECT_EQ(rv, OK);
- }
- SendClientRequest();
-
- scoped_refptr<IOBuffer> buf(new IOBuffer(4096));
- uint32 bytes_read = DrainClientSocket(
- buf.get(), 4096, arraysize(kServerReply) - 1, &callback);
- ASSERT_EQ(bytes_read, arraysize(kServerReply) - 1);
-
- // 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.get(), 4096, callback.callback());
- ASSERT_EQ(ERR_IO_PENDING, rv);
- CloseServerSocket();
- EXPECT_EQ(0, callback.WaitForResult());
-}
-
-TEST_P(TransportClientSocketTest, Read_SmallChunks) {
- TestCompletionCallback callback;
- int rv = sock_->Connect(callback.callback());
- if (rv != OK) {
- ASSERT_EQ(rv, ERR_IO_PENDING);
-
- rv = callback.WaitForResult();
- EXPECT_EQ(rv, OK);
- }
- SendClientRequest();
-
- scoped_refptr<IOBuffer> buf(new IOBuffer(1));
- uint32 bytes_read = 0;
- while (bytes_read < arraysize(kServerReply) - 1) {
- rv = sock_->Read(buf.get(), 1, callback.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.get(), 1, callback.callback());
- ASSERT_EQ(ERR_IO_PENDING, rv);
- CloseServerSocket();
- EXPECT_EQ(0, callback.WaitForResult());
-}
-
-TEST_P(TransportClientSocketTest, Read_Interrupted) {
- TestCompletionCallback callback;
- int rv = sock_->Connect(callback.callback());
- if (rv != OK) {
- ASSERT_EQ(ERR_IO_PENDING, rv);
-
- rv = callback.WaitForResult();
- EXPECT_EQ(rv, OK);
- }
- SendClientRequest();
-
- // Do a partial read and then exit. This test should not crash!
- scoped_refptr<IOBuffer> buf(new IOBuffer(16));
- rv = sock_->Read(buf.get(), 16, callback.callback());
- EXPECT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
-
- if (rv == ERR_IO_PENDING)
- rv = callback.WaitForResult();
-
- EXPECT_NE(0, rv);
-}
-
-TEST_P(TransportClientSocketTest, DISABLED_FullDuplex_ReadFirst) {
- TestCompletionCallback callback;
- int rv = sock_->Connect(callback.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.get(), kBufLen, callback.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.get(), kWriteBufLen, write_callback.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_P(TransportClientSocketTest, DISABLED_FullDuplex_WriteFirst) {
- TestCompletionCallback callback;
- int rv = sock_->Connect(callback.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.get(), kWriteBufLen, write_callback.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.get(), kBufLen, callback.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 net
« net/socket/tcp_client_socket_unittest.cc ('K') | « net/socket/tcp_client_socket_unittest.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698