1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
7 #include "base/compiler_specific.h"
8 #include "base/memory/ref_counted.h"
9 #include "base/message_loop/message_loop.h"
10 #include "base/message_loop/message_loop_proxy.h"
11 #include "base/single_thread_task_runner.h"
12 #include "base/threading/platform_thread.h"
13 #include "base/threading/thread.h"
14 #include "base/time/time.h"
15 #include "chrome/test/chromedriver/net/sync_websocket_impl.h"
16 #include "chrome/test/chromedriver/net/test_http_server.h"
17 #include "chrome/test/chromedriver/net/url_request_context_getter.h"
18 #include "testing/gtest/include/gtest/gtest.h"
23 class SyncWebSocketImplTest
: public testing::Test
{
25 SyncWebSocketImplTest()
26 : client_thread_("ClientThread"),
27 long_timeout_(base::TimeDelta::FromMinutes(1)) {}
28 virtual ~SyncWebSocketImplTest() {}
30 virtual void SetUp() OVERRIDE
{
31 base::Thread::Options
options(base::MessageLoop::TYPE_IO
, 0);
32 ASSERT_TRUE(client_thread_
.StartWithOptions(options
));
33 context_getter_
= new URLRequestContextGetter(
34 client_thread_
.message_loop_proxy());
35 ASSERT_TRUE(server_
.Start());
38 virtual void TearDown() OVERRIDE
{
42 base::Thread client_thread_
;
43 TestHttpServer server_
;
44 scoped_refptr
<URLRequestContextGetter
> context_getter_
;
45 const base::TimeDelta long_timeout_
;
50 TEST_F(SyncWebSocketImplTest
, CreateDestroy
) {
51 SyncWebSocketImpl
sock(context_getter_
.get());
54 TEST_F(SyncWebSocketImplTest
, Connect
) {
55 SyncWebSocketImpl
sock(context_getter_
.get());
56 ASSERT_TRUE(sock
.Connect(server_
.web_socket_url()));
59 TEST_F(SyncWebSocketImplTest
, ConnectFail
) {
60 SyncWebSocketImpl
sock(context_getter_
.get());
61 ASSERT_FALSE(sock
.Connect(GURL("ws://127.0.0.1:33333")));
64 TEST_F(SyncWebSocketImplTest
, SendReceive
) {
65 SyncWebSocketImpl
sock(context_getter_
.get());
66 ASSERT_TRUE(sock
.Connect(server_
.web_socket_url()));
67 ASSERT_TRUE(sock
.Send("hi"));
71 sock
.ReceiveNextMessage(&message
, long_timeout_
));
72 ASSERT_STREQ("hi", message
.c_str());
75 TEST_F(SyncWebSocketImplTest
, SendReceiveTimeout
) {
76 SyncWebSocketImpl
sock(context_getter_
.get());
77 ASSERT_TRUE(sock
.Connect(server_
.web_socket_url()));
78 ASSERT_TRUE(sock
.Send("hi"));
81 SyncWebSocket::kTimeout
,
82 sock
.ReceiveNextMessage(
83 &message
, base::TimeDelta()));
86 TEST_F(SyncWebSocketImplTest
, SendReceiveLarge
) {
87 SyncWebSocketImpl
sock(context_getter_
.get());
88 ASSERT_TRUE(sock
.Connect(server_
.web_socket_url()));
89 std::string
wrote_message(10 << 20, 'a');
90 ASSERT_TRUE(sock
.Send(wrote_message
));
94 sock
.ReceiveNextMessage(&message
, long_timeout_
));
95 ASSERT_EQ(wrote_message
.length(), message
.length());
96 ASSERT_EQ(wrote_message
, message
);
99 TEST_F(SyncWebSocketImplTest
, SendReceiveMany
) {
100 SyncWebSocketImpl
sock(context_getter_
.get());
101 ASSERT_TRUE(sock
.Connect(server_
.web_socket_url()));
102 ASSERT_TRUE(sock
.Send("1"));
103 ASSERT_TRUE(sock
.Send("2"));
107 sock
.ReceiveNextMessage(&message
, long_timeout_
));
108 ASSERT_STREQ("1", message
.c_str());
109 ASSERT_TRUE(sock
.Send("3"));
112 sock
.ReceiveNextMessage(&message
, long_timeout_
));
113 ASSERT_STREQ("2", message
.c_str());
116 sock
.ReceiveNextMessage(&message
, long_timeout_
));
117 ASSERT_STREQ("3", message
.c_str());
120 TEST_F(SyncWebSocketImplTest
, CloseOnReceive
) {
121 server_
.SetMessageAction(TestHttpServer::kCloseOnMessage
);
122 SyncWebSocketImpl
sock(context_getter_
.get());
123 ASSERT_TRUE(sock
.Connect(server_
.web_socket_url()));
124 ASSERT_TRUE(sock
.Send("1"));
127 SyncWebSocket::kDisconnected
,
128 sock
.ReceiveNextMessage(&message
, long_timeout_
));
129 ASSERT_STREQ("", message
.c_str());
132 TEST_F(SyncWebSocketImplTest
, CloseOnSend
) {
133 SyncWebSocketImpl
sock(context_getter_
.get());
134 ASSERT_TRUE(sock
.Connect(server_
.web_socket_url()));
136 ASSERT_FALSE(sock
.Send("1"));
139 TEST_F(SyncWebSocketImplTest
, Reconnect
) {
140 SyncWebSocketImpl
sock(context_getter_
.get());
141 ASSERT_TRUE(sock
.Connect(server_
.web_socket_url()));
142 ASSERT_TRUE(sock
.Send("1"));
143 // Wait for SyncWebSocket to receive the response from the server.
144 base::TimeTicks deadline
=
145 base::TimeTicks::Now() + base::TimeDelta::FromSeconds(20);
146 while (base::TimeTicks::Now() < deadline
) {
147 if (sock
.IsConnected() && !sock
.HasNextMessage())
148 base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(10));
153 ASSERT_FALSE(sock
.Send("2"));
154 ASSERT_FALSE(sock
.IsConnected());
156 ASSERT_TRUE(sock
.HasNextMessage());
157 ASSERT_TRUE(sock
.Connect(server_
.web_socket_url()));
158 ASSERT_FALSE(sock
.HasNextMessage());
159 ASSERT_TRUE(sock
.Send("3"));
163 sock
.ReceiveNextMessage(&message
, long_timeout_
));
164 ASSERT_STREQ("3", message
.c_str());
165 ASSERT_FALSE(sock
.HasNextMessage());