Chromium Code Reviews| 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 |