summaryrefslogtreecommitdiffstats
path: root/net/socket/tcp_server_socket_unittest.cc
diff options
context:
space:
mode:
authorsergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-18 23:03:32 +0000
committersergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-18 23:03:32 +0000
commit3871252036dec25ea2dca4622be40264a25b61d3 (patch)
tree67d45091d78abb5234b286437567f217dcd275cf /net/socket/tcp_server_socket_unittest.cc
parent2b4f812537173e2ab27a9f9b94de3b4da4a5d22e (diff)
downloadchromium_src-3871252036dec25ea2dca4622be40264a25b61d3.zip
chromium_src-3871252036dec25ea2dca4622be40264a25b61d3.tar.gz
chromium_src-3871252036dec25ea2dca4622be40264a25b61d3.tar.bz2
Added TCPServerSocket.
BUG=None TEST=Unittests Review URL: http://codereview.chromium.org/6820057 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@82020 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/socket/tcp_server_socket_unittest.cc')
-rw-r--r--net/socket/tcp_server_socket_unittest.cc146
1 files changed, 146 insertions, 0 deletions
diff --git a/net/socket/tcp_server_socket_unittest.cc b/net/socket/tcp_server_socket_unittest.cc
new file mode 100644
index 0000000..59fa4c0
--- /dev/null
+++ b/net/socket/tcp_server_socket_unittest.cc
@@ -0,0 +1,146 @@
+// Copyright (c) 2011 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_server_socket.h"
+
+#include "base/compiler_specific.h"
+#include "base/scoped_ptr.h"
+#include "net/base/address_list.h"
+#include "net/base/ip_endpoint.h"
+#include "net/base/net_errors.h"
+#include "net/base/sys_addrinfo.h"
+#include "net/base/test_completion_callback.h"
+#include "net/socket/tcp_client_socket.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "testing/platform_test.h"
+
+namespace net {
+
+namespace {
+const int kListenBacklog = 5;
+
+class TCPServerSocketTest : public PlatformTest {
+ protected:
+ TCPServerSocketTest()
+ : socket_(NULL, NetLog::Source()) {
+ }
+
+ void SetUp() OVERRIDE {
+ IPEndPoint address;
+ ParseAddress("127.0.0.1", 0, &address);
+ ASSERT_EQ(OK, socket_.Listen(address, kListenBacklog));
+ ASSERT_EQ(OK, socket_.GetLocalAddress(&local_address_));
+ }
+
+ void ParseAddress(std::string ip_str, int port, IPEndPoint* address) {
+ IPAddressNumber ip_number;
+ bool rv = ParseIPLiteralToNumber(ip_str, &ip_number);
+ if (!rv)
+ return;
+ *address = IPEndPoint(ip_number, port);
+ }
+
+ static IPEndPoint GetPeerAddress(ClientSocket* socket) {
+ AddressList address;
+ EXPECT_EQ(OK, socket->GetPeerAddress(&address));
+ IPEndPoint endpoint;
+ EXPECT_TRUE(endpoint.FromSockAddr(
+ address.head()->ai_addr, address.head()->ai_addrlen));
+ return endpoint;
+ }
+
+ TCPServerSocket socket_;
+ IPEndPoint local_address_;
+};
+
+TEST_F(TCPServerSocketTest, Accept) {
+ TestCompletionCallback connect_callback;
+ TCPClientSocket connecting_socket(AddressList(local_address_.address(),
+ local_address_.port(), false),
+ NULL, NetLog::Source());
+ connecting_socket.Connect(&connect_callback);
+
+ TestCompletionCallback accept_callback;
+ scoped_ptr<ClientSocket> accepted_socket;
+ int result = socket_.Accept(&accepted_socket, &accept_callback);
+ if (result == ERR_IO_PENDING)
+ result = accept_callback.WaitForResult();
+ ASSERT_EQ(OK, result);
+
+ ASSERT_TRUE(accepted_socket.get() != NULL);
+
+ // Both sockets should be on the loopback network interface.
+ EXPECT_EQ(GetPeerAddress(accepted_socket.get()).address(),
+ local_address_.address());
+
+ EXPECT_EQ(OK, connect_callback.WaitForResult());
+}
+
+// Test Accept() callback.
+TEST_F(TCPServerSocketTest, AcceptAsync) {
+ TestCompletionCallback accept_callback;
+ scoped_ptr<ClientSocket> accepted_socket;
+
+ ASSERT_EQ(ERR_IO_PENDING, socket_.Accept(&accepted_socket, &accept_callback));
+
+ TestCompletionCallback connect_callback;
+ TCPClientSocket connecting_socket(AddressList(local_address_.address(),
+ local_address_.port(), false),
+ NULL, NetLog::Source());
+ connecting_socket.Connect(&connect_callback);
+
+ EXPECT_EQ(OK, connect_callback.WaitForResult());
+ EXPECT_EQ(OK, accept_callback.WaitForResult());
+
+ EXPECT_TRUE(accepted_socket != NULL);
+
+ // Both sockets should be on the loopback network interface.
+ EXPECT_EQ(GetPeerAddress(accepted_socket.get()).address(),
+ local_address_.address());
+}
+
+// Accept two connections simultaneously.
+TEST_F(TCPServerSocketTest, Accept2Connections) {
+ TestCompletionCallback accept_callback;
+ scoped_ptr<ClientSocket> accepted_socket;
+
+ ASSERT_EQ(ERR_IO_PENDING,
+ socket_.Accept(&accepted_socket, &accept_callback));
+
+ TestCompletionCallback connect_callback;
+ TCPClientSocket connecting_socket(AddressList(local_address_.address(),
+ local_address_.port(), false),
+ NULL, NetLog::Source());
+ connecting_socket.Connect(&connect_callback);
+
+ TestCompletionCallback connect_callback2;
+ TCPClientSocket connecting_socket2(AddressList(local_address_.address(),
+ local_address_.port(), false),
+ NULL, NetLog::Source());
+ connecting_socket2.Connect(&connect_callback2);
+
+ EXPECT_EQ(OK, accept_callback.WaitForResult());
+
+ TestCompletionCallback accept_callback2;
+ scoped_ptr<ClientSocket> accepted_socket2;
+ int result = socket_.Accept(&accepted_socket2, &accept_callback2);
+ if (result == ERR_IO_PENDING)
+ result = accept_callback2.WaitForResult();
+ ASSERT_EQ(OK, result);
+
+ EXPECT_EQ(OK, connect_callback.WaitForResult());
+
+ EXPECT_TRUE(accepted_socket != NULL);
+ EXPECT_TRUE(accepted_socket2 != NULL);
+ EXPECT_NE(accepted_socket.get(), accepted_socket2.get());
+
+ EXPECT_EQ(GetPeerAddress(accepted_socket.get()).address(),
+ local_address_.address());
+ EXPECT_EQ(GetPeerAddress(accepted_socket2.get()).address(),
+ local_address_.address());
+}
+
+} // namespace
+
+} // namespace net