OLD | NEW |
---|---|
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/extensions/api/cast_channel/cast_socket.h" | 5 #include "chrome/browser/extensions/api/cast_channel/cast_socket.h" |
6 | 6 |
7 #include "base/message_loop/message_loop.h" | 7 #include "base/message_loop/message_loop.h" |
8 #include "base/run_loop.h" | 8 #include "base/run_loop.h" |
9 #include "base/strings/string_number_conversions.h" | 9 #include "base/strings/string_number_conversions.h" |
10 #include "base/sys_byteorder.h" | 10 #include "base/sys_byteorder.h" |
11 #include "chrome/browser/extensions/api/cast_channel/cast_channel.pb.h" | 11 #include "chrome/browser/extensions/api/cast_channel/cast_channel.pb.h" |
12 #include "chrome/browser/extensions/api/cast_channel/cast_message_util.h" | 12 #include "chrome/browser/extensions/api/cast_channel/cast_message_util.h" |
13 #include "net/base/address_list.h" | 13 #include "net/base/address_list.h" |
14 #include "net/base/capturing_net_log.h" | 14 #include "net/base/capturing_net_log.h" |
15 #include "net/base/net_errors.h" | 15 #include "net/base/net_errors.h" |
16 #include "net/base/net_util.h" | 16 #include "net/base/net_util.h" |
17 #include "net/socket/socket_test_util.h" | 17 #include "net/socket/socket_test_util.h" |
18 #include "net/socket/ssl_client_socket.h" | 18 #include "net/socket/ssl_client_socket.h" |
19 #include "net/socket/tcp_client_socket.h" | 19 #include "net/socket/tcp_client_socket.h" |
20 #include "net/ssl/ssl_info.h" | 20 #include "net/ssl/ssl_info.h" |
21 #include "testing/gmock/include/gmock/gmock.h" | 21 #include "testing/gmock/include/gmock/gmock.h" |
22 #include "testing/gtest/include/gtest/gtest.h" | 22 #include "testing/gtest/include/gtest/gtest.h" |
23 | 23 |
24 const int64 kDistantTimeoutMillis = 100000; // 100 seconds (never hit). | |
25 const int64 kImmediateTimeoutMillis = 100; // 0.001 seconds. | |
26 | |
24 using ::testing::_; | 27 using ::testing::_; |
25 using ::testing::A; | 28 using ::testing::A; |
26 using ::testing::DoAll; | 29 using ::testing::DoAll; |
27 using ::testing::Return; | 30 using ::testing::Return; |
28 using ::testing::SaveArg; | 31 using ::testing::SaveArg; |
29 | 32 |
30 namespace { | 33 namespace { |
31 const char* kTestData[4] = { | 34 const char* kTestData[4] = { |
32 "Hello, World!", | 35 "Hello, World!", |
33 "Goodbye, World!", | 36 "Goodbye, World!", |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
72 MOCK_METHOD2(OnMessage, void(const CastSocket* socket, | 75 MOCK_METHOD2(OnMessage, void(const CastSocket* socket, |
73 const MessageInfo& message)); | 76 const MessageInfo& message)); |
74 }; | 77 }; |
75 | 78 |
76 class MockTCPSocket : public net::TCPClientSocket { | 79 class MockTCPSocket : public net::TCPClientSocket { |
77 public: | 80 public: |
78 explicit MockTCPSocket(const net::MockConnect& connect_data) : | 81 explicit MockTCPSocket(const net::MockConnect& connect_data) : |
79 TCPClientSocket(net::AddressList(), NULL, net::NetLog::Source()), | 82 TCPClientSocket(net::AddressList(), NULL, net::NetLog::Source()), |
80 connect_data_(connect_data) { } | 83 connect_data_(connect_data) { } |
81 | 84 |
85 explicit MockTCPSocket(bool do_nothing) : | |
86 TCPClientSocket(net::AddressList(), NULL, net::NetLog::Source()) { | |
87 CHECK(do_nothing); | |
88 do_nothing_ = true; | |
89 } | |
90 | |
82 virtual int Connect(const net::CompletionCallback& callback) OVERRIDE { | 91 virtual int Connect(const net::CompletionCallback& callback) OVERRIDE { |
92 if (do_nothing_) { | |
93 return net::ERR_IO_PENDING; | |
94 } | |
95 | |
83 if (connect_data_.mode == net::ASYNC) { | 96 if (connect_data_.mode == net::ASYNC) { |
84 CHECK_NE(connect_data_.result, net::ERR_IO_PENDING); | 97 CHECK_NE(connect_data_.result, net::ERR_IO_PENDING); |
85 base::MessageLoop::current()->PostTask( | 98 base::MessageLoop::current()->PostTask( |
86 FROM_HERE, | 99 FROM_HERE, |
87 base::Bind(callback, connect_data_.result)); | 100 base::Bind(callback, connect_data_.result)); |
88 return net::ERR_IO_PENDING; | 101 return net::ERR_IO_PENDING; |
89 } else { | 102 } else { |
90 return connect_data_.result; | 103 return connect_data_.result; |
91 } | 104 } |
92 } | 105 } |
(...skipping 12 matching lines...) Expand all Loading... | |
105 int(net::IOBuffer*, int, const net::CompletionCallback&)); | 118 int(net::IOBuffer*, int, const net::CompletionCallback&)); |
106 MOCK_METHOD3(Write, | 119 MOCK_METHOD3(Write, |
107 int(net::IOBuffer*, int, const net::CompletionCallback&)); | 120 int(net::IOBuffer*, int, const net::CompletionCallback&)); |
108 | 121 |
109 virtual void Disconnect() OVERRIDE { | 122 virtual void Disconnect() OVERRIDE { |
110 // Do nothing in tests | 123 // Do nothing in tests |
111 } | 124 } |
112 | 125 |
113 private: | 126 private: |
114 net::MockConnect connect_data_; | 127 net::MockConnect connect_data_; |
128 bool do_nothing_; | |
115 }; | 129 }; |
116 | 130 |
117 class CompleteHandler { | 131 class CompleteHandler { |
118 public: | 132 public: |
119 CompleteHandler() {} | 133 CompleteHandler() {} |
120 MOCK_METHOD1(OnCloseComplete, void(int result)); | 134 MOCK_METHOD1(OnCloseComplete, void(int result)); |
121 MOCK_METHOD1(OnConnectComplete, void(int result)); | 135 MOCK_METHOD1(OnConnectComplete, void(int result)); |
122 MOCK_METHOD1(OnWriteComplete, void(int result)); | 136 MOCK_METHOD1(OnWriteComplete, void(int result)); |
123 private: | 137 private: |
124 DISALLOW_COPY_AND_ASSIGN(CompleteHandler); | 138 DISALLOW_COPY_AND_ASSIGN(CompleteHandler); |
125 }; | 139 }; |
126 | 140 |
127 class TestCastSocket : public CastSocket { | 141 class TestCastSocket : public CastSocket { |
128 public: | 142 public: |
129 static scoped_ptr<TestCastSocket> Create( | 143 static scoped_ptr<TestCastSocket> Create( |
130 MockCastSocketDelegate* delegate) { | 144 MockCastSocketDelegate* delegate) { |
131 return scoped_ptr<TestCastSocket>( | 145 return scoped_ptr<TestCastSocket>( |
132 new TestCastSocket(delegate, CreateIPEndPoint(), | 146 new TestCastSocket(delegate, CreateIPEndPoint(), |
133 CHANNEL_AUTH_TYPE_SSL)); | 147 CHANNEL_AUTH_TYPE_SSL, |
148 kDistantTimeoutMillis)); | |
134 } | 149 } |
135 | 150 |
136 static scoped_ptr<TestCastSocket> CreateSecure( | 151 static scoped_ptr<TestCastSocket> CreateSecure( |
137 MockCastSocketDelegate* delegate) { | 152 MockCastSocketDelegate* delegate) { |
138 return scoped_ptr<TestCastSocket>( | 153 return scoped_ptr<TestCastSocket>( |
139 new TestCastSocket(delegate, CreateIPEndPoint(), | 154 new TestCastSocket(delegate, CreateIPEndPoint(), |
140 CHANNEL_AUTH_TYPE_SSL_VERIFIED)); | 155 CHANNEL_AUTH_TYPE_SSL_VERIFIED, |
156 kDistantTimeoutMillis)); | |
157 } | |
158 | |
159 static scoped_ptr<TestCastSocket> CreateDoomedToTimeout( | |
mark a. foltz
2014/07/15 22:18:16
Instead of fudging timeouts the cleaner way to tes
Kevin M
2014/07/16 22:59:42
Done. New approach uses Timer.
| |
160 MockCastSocketDelegate* delegate) { | |
161 return scoped_ptr<TestCastSocket>( | |
162 new TestCastSocket(delegate, CreateIPEndPoint(), | |
163 CHANNEL_AUTH_TYPE_SSL_VERIFIED, | |
164 kImmediateTimeoutMillis)); | |
141 } | 165 } |
142 | 166 |
143 explicit TestCastSocket(MockCastSocketDelegate* delegate, | 167 explicit TestCastSocket(MockCastSocketDelegate* delegate, |
144 const net::IPEndPoint& ip_endpoint, | 168 const net::IPEndPoint& ip_endpoint, |
145 ChannelAuthType channel_auth) : | 169 ChannelAuthType channel_auth, |
170 int64 timeout_ms) : | |
146 CastSocket("abcdefg", ip_endpoint, channel_auth, delegate, | 171 CastSocket("abcdefg", ip_endpoint, channel_auth, delegate, |
147 &capturing_net_log_), | 172 &capturing_net_log_, timeout_ms), |
148 ip_(ip_endpoint), | 173 ip_(ip_endpoint), |
149 connect_index_(0), | 174 connect_index_(0), |
150 extract_cert_result_(true), | 175 extract_cert_result_(true), |
151 verify_challenge_result_(true) { | 176 verify_challenge_result_(true), |
152 } | 177 tcp_unresponsive_(false) {} |
153 | 178 |
154 static net::IPEndPoint CreateIPEndPoint() { | 179 static net::IPEndPoint CreateIPEndPoint() { |
155 net::IPAddressNumber number; | 180 net::IPAddressNumber number; |
156 number.push_back(192); | 181 number.push_back(192); |
157 number.push_back(0); | 182 number.push_back(0); |
158 number.push_back(0); | 183 number.push_back(0); |
159 number.push_back(1); | 184 number.push_back(1); |
160 return net::IPEndPoint(number, 8009); | 185 return net::IPEndPoint(number, 8009); |
161 } | 186 } |
162 | 187 |
(...skipping 11 matching lines...) Expand all Loading... | |
174 } | 199 } |
175 void SetupSsl1Connect(net::IoMode mode, int result) { | 200 void SetupSsl1Connect(net::IoMode mode, int result) { |
176 ssl_connect_data_[0].reset(new net::MockConnect(mode, result)); | 201 ssl_connect_data_[0].reset(new net::MockConnect(mode, result)); |
177 } | 202 } |
178 void SetupTcp2Connect(net::IoMode mode, int result) { | 203 void SetupTcp2Connect(net::IoMode mode, int result) { |
179 tcp_connect_data_[1].reset(new net::MockConnect(mode, result)); | 204 tcp_connect_data_[1].reset(new net::MockConnect(mode, result)); |
180 } | 205 } |
181 void SetupSsl2Connect(net::IoMode mode, int result) { | 206 void SetupSsl2Connect(net::IoMode mode, int result) { |
182 ssl_connect_data_[1].reset(new net::MockConnect(mode, result)); | 207 ssl_connect_data_[1].reset(new net::MockConnect(mode, result)); |
183 } | 208 } |
209 void SetupTcp1ConnectUnresponsive() { | |
210 tcp_unresponsive_ = true; | |
211 } | |
184 void AddWriteResult(const net::MockWrite& write) { | 212 void AddWriteResult(const net::MockWrite& write) { |
185 writes_.push_back(write); | 213 writes_.push_back(write); |
186 } | 214 } |
187 void AddWriteResult(net::IoMode mode, int result) { | 215 void AddWriteResult(net::IoMode mode, int result) { |
188 AddWriteResult(net::MockWrite(mode, result)); | 216 AddWriteResult(net::MockWrite(mode, result)); |
189 } | 217 } |
190 void AddWriteResultForMessage(net::IoMode mode, const std::string& msg) { | 218 void AddWriteResultForMessage(net::IoMode mode, const std::string& msg) { |
191 AddWriteResult(mode, msg.size()); | 219 AddWriteResult(mode, msg.size()); |
192 } | 220 } |
193 void AddWriteResultForMessage(net::IoMode mode, | 221 void AddWriteResultForMessage(net::IoMode mode, |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
230 | 258 |
231 void SetExtractCertResult(bool value) { | 259 void SetExtractCertResult(bool value) { |
232 extract_cert_result_ = value; | 260 extract_cert_result_ = value; |
233 } | 261 } |
234 void SetVerifyChallengeResult(bool value) { | 262 void SetVerifyChallengeResult(bool value) { |
235 verify_challenge_result_ = value; | 263 verify_challenge_result_ = value; |
236 } | 264 } |
237 | 265 |
238 private: | 266 private: |
239 virtual scoped_ptr<net::TCPClientSocket> CreateTcpSocket() OVERRIDE { | 267 virtual scoped_ptr<net::TCPClientSocket> CreateTcpSocket() OVERRIDE { |
240 net::MockConnect* connect_data = tcp_connect_data_[connect_index_].get(); | 268 if (tcp_unresponsive_) { |
241 connect_data->peer_addr = ip_; | 269 return scoped_ptr<net::TCPClientSocket>(new MockTCPSocket(true)); |
242 return scoped_ptr<net::TCPClientSocket>(new MockTCPSocket(*connect_data)); | 270 } else { |
271 net::MockConnect* connect_data = tcp_connect_data_[connect_index_].get(); | |
272 connect_data->peer_addr = ip_; | |
273 return scoped_ptr<net::TCPClientSocket>(new MockTCPSocket(*connect_data)); | |
274 } | |
243 } | 275 } |
244 | 276 |
245 virtual scoped_ptr<net::SSLClientSocket> CreateSslSocket( | 277 virtual scoped_ptr<net::SSLClientSocket> CreateSslSocket( |
246 scoped_ptr<net::StreamSocket> socket) OVERRIDE { | 278 scoped_ptr<net::StreamSocket> socket) OVERRIDE { |
247 net::MockConnect* connect_data = ssl_connect_data_[connect_index_].get(); | 279 net::MockConnect* connect_data = ssl_connect_data_[connect_index_].get(); |
248 connect_data->peer_addr = ip_; | 280 connect_data->peer_addr = ip_; |
249 ++connect_index_; | 281 ++connect_index_; |
250 | 282 |
251 ssl_data_.reset(new net::StaticSocketDataProvider( | 283 ssl_data_.reset(new net::StaticSocketDataProvider( |
252 reads_.data(), reads_.size(), writes_.data(), writes_.size())); | 284 reads_.data(), reads_.size(), writes_.data(), writes_.size())); |
(...skipping 22 matching lines...) Expand all Loading... | |
275 // Simulated read / write data | 307 // Simulated read / write data |
276 std::vector<net::MockWrite> writes_; | 308 std::vector<net::MockWrite> writes_; |
277 std::vector<net::MockRead> reads_; | 309 std::vector<net::MockRead> reads_; |
278 scoped_ptr<net::SocketDataProvider> ssl_data_; | 310 scoped_ptr<net::SocketDataProvider> ssl_data_; |
279 // Number of times Connect method is called | 311 // Number of times Connect method is called |
280 size_t connect_index_; | 312 size_t connect_index_; |
281 // Simulated result of peer cert extraction. | 313 // Simulated result of peer cert extraction. |
282 bool extract_cert_result_; | 314 bool extract_cert_result_; |
283 // Simulated result of verifying challenge reply. | 315 // Simulated result of verifying challenge reply. |
284 bool verify_challenge_result_; | 316 bool verify_challenge_result_; |
317 // If true, makes TCP connection process stall. For timeout testing. | |
318 bool tcp_unresponsive_; | |
285 }; | 319 }; |
286 | 320 |
287 class CastSocketTest : public testing::Test { | 321 class CastSocketTest : public testing::Test { |
288 public: | 322 public: |
289 CastSocketTest() {} | 323 CastSocketTest() {} |
290 virtual ~CastSocketTest() {} | 324 virtual ~CastSocketTest() {} |
291 | 325 |
292 virtual void SetUp() OVERRIDE { | 326 virtual void SetUp() OVERRIDE { |
293 // Create a few test messages | 327 // Create a few test messages |
294 for (size_t i = 0; i < arraysize(test_messages_); i++) { | 328 for (size_t i = 0; i < arraysize(test_messages_); i++) { |
(...skipping 28 matching lines...) Expand all Loading... | |
323 } | 357 } |
324 | 358 |
325 void CreateCastSocket() { | 359 void CreateCastSocket() { |
326 socket_ = TestCastSocket::Create(&mock_delegate_); | 360 socket_ = TestCastSocket::Create(&mock_delegate_); |
327 } | 361 } |
328 | 362 |
329 void CreateCastSocketSecure() { | 363 void CreateCastSocketSecure() { |
330 socket_ = TestCastSocket::CreateSecure(&mock_delegate_); | 364 socket_ = TestCastSocket::CreateSecure(&mock_delegate_); |
331 } | 365 } |
332 | 366 |
367 void CreateCastSocketUnresponsive() { | |
368 socket_ = TestCastSocket::CreateDoomedToTimeout(&mock_delegate_); | |
369 } | |
370 | |
333 // Sets up CastSocket::Connect to succeed. | 371 // Sets up CastSocket::Connect to succeed. |
334 // Connecting the socket also starts the read loop; so we add a mock | 372 // Connecting the socket also starts the read loop; so we add a mock |
335 // read result that returns IO_PENDING and callback is never fired. | 373 // read result that returns IO_PENDING and callback is never fired. |
336 void ConnectHelper() { | 374 void ConnectHelper() { |
337 socket_->SetupTcp1Connect(net::SYNCHRONOUS, net::OK); | 375 socket_->SetupTcp1Connect(net::SYNCHRONOUS, net::OK); |
338 socket_->SetupSsl1Connect(net::SYNCHRONOUS, net::OK); | 376 socket_->SetupSsl1Connect(net::SYNCHRONOUS, net::OK); |
339 socket_->AddReadResult(net::ASYNC, net::ERR_IO_PENDING); | 377 socket_->AddReadResult(net::ASYNC, net::ERR_IO_PENDING); |
340 | 378 |
341 EXPECT_CALL(handler_, OnConnectComplete(net::OK)); | 379 EXPECT_CALL(handler_, OnConnectComplete(net::OK)); |
342 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, | 380 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
(...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
513 | 551 |
514 EXPECT_CALL(handler_, OnConnectComplete(net::ERR_FAILED)); | 552 EXPECT_CALL(handler_, OnConnectComplete(net::ERR_FAILED)); |
515 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, | 553 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
516 base::Unretained(&handler_))); | 554 base::Unretained(&handler_))); |
517 RunPendingTasks(); | 555 RunPendingTasks(); |
518 | 556 |
519 EXPECT_EQ(cast_channel::READY_STATE_CLOSED, socket_->ready_state()); | 557 EXPECT_EQ(cast_channel::READY_STATE_CLOSED, socket_->ready_state()); |
520 EXPECT_EQ(cast_channel::CHANNEL_ERROR_CONNECT_ERROR, socket_->error_state()); | 558 EXPECT_EQ(cast_channel::CHANNEL_ERROR_CONNECT_ERROR, socket_->error_state()); |
521 } | 559 } |
522 | 560 |
561 // Test connection error - timeout | |
562 TEST_F(CastSocketTest, TestConnectTcpTimeoutError) { | |
563 CreateCastSocketUnresponsive(); | |
564 | |
565 socket_->SetupTcp1ConnectUnresponsive(); | |
566 EXPECT_CALL(handler_, OnConnectComplete(net::ERR_TIMED_OUT)); | |
567 EXPECT_CALL(mock_delegate_, | |
568 OnError(socket_.get(), | |
569 cast_channel::CHANNEL_ERROR_CONNECT_ERROR)); | |
570 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, | |
571 base::Unretained(&handler_))); | |
572 RunPendingTasks(); | |
573 EXPECT_EQ(cast_channel::READY_STATE_CONNECTING, socket_->ready_state()); | |
574 EXPECT_EQ(cast_channel::CHANNEL_ERROR_NONE, socket_->error_state()); | |
575 | |
576 // Allow for the timeout to fire by sleeping (plus some padding to protect | |
577 // against timing-related flakiness). | |
mark a. foltz
2014/07/15 22:18:16
A mock clock would definitely be better here.
Kevin M
2014/07/16 22:59:42
Done.
| |
578 base::PlatformThread::Sleep( | |
579 base::TimeDelta::FromMilliseconds(kImmediateTimeoutMillis + 200)); | |
580 RunPendingTasks(); | |
581 | |
582 EXPECT_EQ(cast_channel::READY_STATE_CLOSED, socket_->ready_state()); | |
583 EXPECT_EQ(cast_channel::CHANNEL_ERROR_CONNECT_ERROR, socket_->error_state()); | |
584 } | |
585 | |
523 // Test connection error - SSL connect fails (async) | 586 // Test connection error - SSL connect fails (async) |
524 TEST_F(CastSocketTest, TestConnectSslConnectErrorAsync) { | 587 TEST_F(CastSocketTest, TestConnectSslConnectErrorAsync) { |
525 CreateCastSocketSecure(); | 588 CreateCastSocketSecure(); |
526 | 589 |
527 socket_->SetupTcp1Connect(net::SYNCHRONOUS, net::OK); | 590 socket_->SetupTcp1Connect(net::SYNCHRONOUS, net::OK); |
528 socket_->SetupSsl1Connect(net::SYNCHRONOUS, net::ERR_FAILED); | 591 socket_->SetupSsl1Connect(net::SYNCHRONOUS, net::ERR_FAILED); |
529 | 592 |
530 EXPECT_CALL(handler_, OnConnectComplete(net::ERR_FAILED)); | 593 EXPECT_CALL(handler_, OnConnectComplete(net::ERR_FAILED)); |
531 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, | 594 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
532 base::Unretained(&handler_))); | 595 base::Unretained(&handler_))); |
533 RunPendingTasks(); | 596 RunPendingTasks(); |
534 | 597 |
535 EXPECT_EQ(cast_channel::READY_STATE_CLOSED, socket_->ready_state()); | 598 EXPECT_EQ(cast_channel::READY_STATE_CLOSED, socket_->ready_state()); |
536 EXPECT_EQ(cast_channel::CHANNEL_ERROR_CONNECT_ERROR, socket_->error_state()); | 599 EXPECT_EQ(cast_channel::CHANNEL_ERROR_CONNECT_ERROR, socket_->error_state()); |
537 } | 600 } |
538 | 601 |
539 // Test connection error - SSL connect fails (async) | 602 // Test connection error - SSL connect fails (sync) |
540 TEST_F(CastSocketTest, TestConnectSslConnectErrorSync) { | 603 TEST_F(CastSocketTest, TestConnectSslConnectErrorSync) { |
541 CreateCastSocketSecure(); | 604 CreateCastSocketSecure(); |
542 | 605 |
543 socket_->SetupTcp1Connect(net::SYNCHRONOUS, net::OK); | 606 socket_->SetupTcp1Connect(net::SYNCHRONOUS, net::OK); |
544 socket_->SetupSsl1Connect(net::ASYNC, net::ERR_FAILED); | 607 socket_->SetupSsl1Connect(net::ASYNC, net::ERR_FAILED); |
545 | 608 |
546 EXPECT_CALL(handler_, OnConnectComplete(net::ERR_FAILED)); | 609 EXPECT_CALL(handler_, OnConnectComplete(net::ERR_FAILED)); |
547 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, | 610 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
548 base::Unretained(&handler_))); | 611 base::Unretained(&handler_))); |
549 RunPendingTasks(); | 612 RunPendingTasks(); |
(...skipping 443 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
993 ConnectHelper(); | 1056 ConnectHelper(); |
994 | 1057 |
995 EXPECT_EQ(cast_channel::READY_STATE_CLOSED, socket_->ready_state()); | 1058 EXPECT_EQ(cast_channel::READY_STATE_CLOSED, socket_->ready_state()); |
996 EXPECT_EQ(cast_channel::CHANNEL_ERROR_INVALID_MESSAGE, | 1059 EXPECT_EQ(cast_channel::CHANNEL_ERROR_INVALID_MESSAGE, |
997 socket_->error_state()); | 1060 socket_->error_state()); |
998 } | 1061 } |
999 | 1062 |
1000 } // namespace cast_channel | 1063 } // namespace cast_channel |
1001 } // namespace api | 1064 } // namespace api |
1002 } // namespace extensions | 1065 } // namespace extensions |
OLD | NEW |