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

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: Created 5 years, 9 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
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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
index 0e2f11d06d5bd5663311f2badbb24279742b961a..5027509323d86c9cb4ef53ff1bc90732b6103ffd 100644
--- a/net/socket/transport_client_socket_unittest.cc
+++ b/net/socket/transport_client_socket_unittest.cc
@@ -5,6 +5,7 @@
#include "net/socket/tcp_client_socket.h"
#include "base/basictypes.h"
+#include "base/bind.h"
#include "base/memory/ref_counted.h"
#include "base/memory/scoped_ptr.h"
#include "net/base/address_list.h"
@@ -16,7 +17,7 @@
#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 "net/socket/tcp_server_socket.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "testing/platform_test.h"
@@ -34,8 +35,7 @@ enum ClientSocketTestTypes {
} // namespace
class TransportClientSocketTest
- : public StreamListenSocket::Delegate,
- public ::testing::TestWithParam<ClientSocketTestTypes> {
+ : public ::testing::TestWithParam<ClientSocketTestTypes> {
public:
TransportClientSocketTest()
: listen_port_(0),
@@ -46,21 +46,6 @@ class TransportClientSocketTest
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;
@@ -69,20 +54,14 @@ class TransportClientSocketTest
connected_sock_.reset();
}
- void PauseServerReads() {
- connected_sock_->PauseReads();
- }
-
- void ResumeServerReads() {
- connected_sock_->ResumeReads();
- }
+ void AcceptCallback(int res) {}
int DrainClientSocket(IOBuffer* buf,
uint32 buf_len,
uint32 bytes_to_read,
TestCompletionCallback* callback);
- void SendClientRequest();
+ void ProcessRequest();
void set_close_server_socket_on_next_send(bool close) {
close_server_socket_on_next_send_ = close;
@@ -95,16 +74,16 @@ class TransportClientSocketTest
scoped_ptr<StreamSocket> sock_;
private:
- scoped_ptr<TCPListenSocket> listen_sock_;
- scoped_ptr<TCPListenSocket> connected_sock_;
+ scoped_ptr<TCPServerSocket> listen_sock_;
+ scoped_ptr<StreamSocket> connected_sock_;
bool close_server_socket_on_next_send_;
};
void TransportClientSocketTest::SetUp() {
::testing::TestWithParam<ClientSocketTestTypes>::SetUp();
+ listen_sock_.reset(new TCPServerSocket(NULL, NetLog::Source()));
// 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;
@@ -112,14 +91,16 @@ void TransportClientSocketTest::SetUp() {
#if defined(OS_WIN)
EnsureWinsockInit();
#endif
mmenke 2015/04/06 18:37:33 Also, we can remove this #if block - creating the
xunjieli 2015/04/08 14:47:19 Done.
+ net::IPAddressNumber address;
+ net::ParseIPLiteralToNumber("127.0.0.1", &address);
for (port = kMinPort; port < kMaxPort; port++) {
mmenke 2015/04/06 18:30:03 While we're here, can we get rid of this loop? I
xunjieli 2015/04/08 14:47:19 Done.
- sock = TCPListenSocket::CreateAndListen("127.0.0.1", port, this);
- if (sock.get())
+ if (listen_sock_->Listen(IPEndPoint(address, port), 1) == net::OK)
break;
}
- ASSERT_TRUE(sock.get() != NULL);
- listen_sock_ = sock.Pass();
listen_port_ = port;
+ listen_sock_->Accept(&connected_sock_,
+ base::Bind(&TransportClientSocketTest::AcceptCallback,
xunjieli 2015/04/03 20:19:23 Using a dummy callback here, not sure if there's a
mmenke 2015/04/06 18:30:03 How about having AcceptCallback quite a base::RunL
xunjieli 2015/04/08 14:47:19 Done. Good idea! thanks
+ base::Unretained(this)));
AddressList addr;
// MockHostResolver resolves everything to 127.0.0.1.
@@ -157,21 +138,47 @@ int TransportClientSocketTest::DrainClientSocket(
return static_cast<int>(bytes_read);
}
-void TransportClientSocketTest::SendClientRequest() {
+void TransportClientSocketTest::ProcessRequest() {
+ // Send client request.
const char request_text[] = "GET / HTTP/1.0\r\n\r\n";
- scoped_refptr<IOBuffer> request_buffer(
- new IOBuffer(arraysize(request_text) - 1));
+ int request_len = arraysize(request_text) - 1;
mmenke 2015/04/06 18:30:03 Much cleaner to have this in a variable. Maybe ju
xunjieli 2015/04/08 14:47:19 Partially done. Sorry, I am not sure what you mean
+ scoped_refptr<IOBuffer> request_buffer(new IOBuffer(request_len));
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());
+ memcpy(request_buffer->data(), request_text, request_len);
+ rv = sock_->Write(request_buffer.get(), request_len, 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));
+ EXPECT_EQ(rv, request_len);
mmenke 2015/04/06 18:30:03 nit: Flip order, expected should go first (Know t
xunjieli 2015/04/08 14:47:19 Done. Right!
+
+ // Confirms that the server receives what client sent.
+ scoped_refptr<IOBufferWithSize> read_buffer(
+ new IOBufferWithSize(request_len + 1));
mmenke 2015/04/06 18:30:03 Is the +1 needed?
xunjieli 2015/04/08 14:47:19 I am not sure. I thought we need to have 1 byte ex
+ TestCompletionCallback read_callback;
+ int read_result = connected_sock_->Read(
+ read_buffer.get(), read_buffer->size(), read_callback.callback());
mmenke 2015/04/06 18:30:03 I don't believe can actually be completely sure we
xunjieli 2015/04/08 14:47:19 Done.
+ read_result = read_callback.GetResult(read_result);
+ ASSERT_EQ(request_len, read_result);
+ std::string message(request_text);
+ std::string received_message(read_buffer->data(), read_result);
+ ASSERT_EQ(message, received_message);
+
+ // Write response.
+ // TODO(dkegel): this might not be long enough to tickle some bugs.
+ TestCompletionCallback write_callback;
+ scoped_refptr<IOBufferWithSize> write_buffer(
+ new IOBufferWithSize(arraysize(kServerReply)));
+ memmove(write_buffer->data(), kServerReply, arraysize(kServerReply) - 1);
+ int write_result =
+ connected_sock_->Write(write_buffer.get(), arraysize(kServerReply) - 1,
+ write_callback.callback());
+ write_result = write_callback.GetResult(write_result);
mmenke 2015/04/06 18:30:03 Should handle ERR_IO_PENDING, like above, and I al
xunjieli 2015/04/08 14:47:19 But GetResult will wait if it is ERR_IO_PENDING ri
+ ASSERT_EQ((int)(arraysize(kServerReply) - 1), write_result);
+ if (close_server_socket_on_next_send_)
+ CloseServerSocket();
}
// TODO(leighton): Add SCTP to this list when it is ready.
@@ -223,7 +230,7 @@ TEST_P(TransportClientSocketTest, IsConnected) {
EXPECT_TRUE(sock_->IsConnectedAndIdle());
// Send the request and wait for the server to respond.
- SendClientRequest();
+ ProcessRequest();
// Drain a single byte so we know we've received some data.
bytes_read = DrainClientSocket(buf.get(), 1, 1, &callback);
@@ -245,7 +252,7 @@ TEST_P(TransportClientSocketTest, IsConnected) {
// This time close the server socket immediately after the server response.
set_close_server_socket_on_next_send(true);
- SendClientRequest();
+ ProcessRequest();
bytes_read = DrainClientSocket(buf.get(), 1, 1, &callback);
ASSERT_EQ(bytes_read, 1u);
@@ -279,7 +286,7 @@ TEST_P(TransportClientSocketTest, Read) {
rv = callback.WaitForResult();
EXPECT_EQ(rv, OK);
}
- SendClientRequest();
+ ProcessRequest();
scoped_refptr<IOBuffer> buf(new IOBuffer(4096));
uint32 bytes_read = DrainClientSocket(
@@ -304,7 +311,7 @@ TEST_P(TransportClientSocketTest, Read_SmallChunks) {
rv = callback.WaitForResult();
EXPECT_EQ(rv, OK);
}
- SendClientRequest();
+ ProcessRequest();
scoped_refptr<IOBuffer> buf(new IOBuffer(1));
uint32 bytes_read = 0;
@@ -337,7 +344,7 @@ TEST_P(TransportClientSocketTest, Read_Interrupted) {
rv = callback.WaitForResult();
EXPECT_EQ(rv, OK);
}
- SendClientRequest();
+ ProcessRequest();
// Do a partial read and then exit. This test should not crash!
scoped_refptr<IOBuffer> buf(new IOBuffer(16));
@@ -366,7 +373,7 @@ TEST_P(TransportClientSocketTest, DISABLED_FullDuplex_ReadFirst) {
rv = sock_->Read(buf.get(), kBufLen, callback.callback());
EXPECT_EQ(ERR_IO_PENDING, rv);
- PauseServerReads();
+ // PauseServerReads();
const int kWriteBufLen = 64 * 1024;
scoped_refptr<IOBuffer> request_buffer(new IOBuffer(kWriteBufLen));
char* request_data = request_buffer->data();
@@ -379,7 +386,7 @@ TEST_P(TransportClientSocketTest, DISABLED_FullDuplex_ReadFirst) {
ASSERT_TRUE(rv >= 0 || rv == ERR_IO_PENDING);
if (rv == ERR_IO_PENDING) {
- ResumeServerReads();
+ // ResumeServerReads();
rv = write_callback.WaitForResult();
break;
}
@@ -403,7 +410,7 @@ TEST_P(TransportClientSocketTest, DISABLED_FullDuplex_WriteFirst) {
EXPECT_EQ(OK, rv);
}
- PauseServerReads();
+ // PauseServerReads();
const int kWriteBufLen = 64 * 1024;
scoped_refptr<IOBuffer> request_buffer(new IOBuffer(kWriteBufLen));
char* request_data = request_buffer->data();
@@ -435,7 +442,7 @@ TEST_P(TransportClientSocketTest, DISABLED_FullDuplex_WriteFirst) {
// run the write and read callbacks to make sure they can handle full duplex
// communications.
- ResumeServerReads();
+ // ResumeServerReads();
rv = write_callback.WaitForResult();
EXPECT_GE(rv, 0);
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698