| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "components/cast_channel/cast_socket.h" | 5 #include "components/cast_channel/cast_socket.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <utility> | 9 #include <utility> |
| 10 #include <vector> | 10 #include <vector> |
| (...skipping 313 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 324 // If true, makes TCP connection process stall. For timeout testing. | 324 // If true, makes TCP connection process stall. For timeout testing. |
| 325 bool tcp_unresponsive_; | 325 bool tcp_unresponsive_; |
| 326 std::unique_ptr<base::MockTimer> mock_timer_; | 326 std::unique_ptr<base::MockTimer> mock_timer_; |
| 327 MockCastTransport* mock_transport_; | 327 MockCastTransport* mock_transport_; |
| 328 | 328 |
| 329 DISALLOW_COPY_AND_ASSIGN(TestCastSocket); | 329 DISALLOW_COPY_AND_ASSIGN(TestCastSocket); |
| 330 }; | 330 }; |
| 331 | 331 |
| 332 class CastSocketTest : public testing::Test { | 332 class CastSocketTest : public testing::Test { |
| 333 public: | 333 public: |
| 334 CastSocketTest() : logger_(new Logger()), delegate_(new MockDelegate) {} | 334 CastSocketTest() |
| 335 : logger_(new Logger()), observer_(new MockCastSocketObserver()) {} |
| 335 ~CastSocketTest() override {} | 336 ~CastSocketTest() override {} |
| 336 | 337 |
| 337 void SetUp() override { EXPECT_CALL(*delegate_, OnMessage(_)).Times(0); } | 338 void SetUp() override { EXPECT_CALL(*observer_, OnMessage(_, _)).Times(0); } |
| 338 | 339 |
| 339 void TearDown() override { | 340 void TearDown() override { |
| 340 if (socket_.get()) { | 341 if (socket_.get()) { |
| 341 EXPECT_CALL(handler_, OnCloseComplete(net::OK)); | 342 EXPECT_CALL(handler_, OnCloseComplete(net::OK)); |
| 342 socket_->Close(base::Bind(&CompleteHandler::OnCloseComplete, | 343 socket_->Close(base::Bind(&CompleteHandler::OnCloseComplete, |
| 343 base::Unretained(&handler_))); | 344 base::Unretained(&handler_))); |
| 344 } | 345 } |
| 345 } | 346 } |
| 346 | 347 |
| 347 void CreateCastSocketSecure() { | 348 void CreateCastSocketSecure() { |
| 348 socket_ = TestCastSocket::CreateSecure(logger_); | 349 socket_ = TestCastSocket::CreateSecure(logger_); |
| 349 } | 350 } |
| 350 | 351 |
| 351 void HandleAuthHandshake() { | 352 void HandleAuthHandshake() { |
| 352 socket_->SetupMockTransport(); | 353 socket_->SetupMockTransport(); |
| 353 CastMessage challenge_proto = CreateAuthChallenge(); | 354 CastMessage challenge_proto = CreateAuthChallenge(); |
| 354 EXPECT_CALL(*socket_->GetMockTransport(), | 355 EXPECT_CALL(*socket_->GetMockTransport(), |
| 355 SendMessage(EqualsProto(challenge_proto), _)) | 356 SendMessage(EqualsProto(challenge_proto), _)) |
| 356 .WillOnce(PostCompletionCallbackTask<1>(net::OK)); | 357 .WillOnce(PostCompletionCallbackTask<1>(net::OK)); |
| 357 EXPECT_CALL(*socket_->GetMockTransport(), Start()); | 358 EXPECT_CALL(*socket_->GetMockTransport(), Start()); |
| 358 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::NONE)); | 359 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::NONE)); |
| 359 socket_->Connect(std::move(delegate_), | 360 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 360 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 361 base::Unretained(&handler_))); | 361 base::Unretained(&handler_))); |
| 362 RunPendingTasks(); | 362 RunPendingTasks(); |
| 363 socket_->GetMockTransport()->current_delegate()->OnMessage( | 363 socket_->GetMockTransport()->current_delegate()->OnMessage( |
| 364 CreateAuthReply()); | 364 CreateAuthReply()); |
| 365 RunPendingTasks(); | 365 RunPendingTasks(); |
| 366 } | 366 } |
| 367 | 367 |
| 368 protected: | 368 protected: |
| 369 // Runs all pending tasks in the message loop. | 369 // Runs all pending tasks in the message loop. |
| 370 void RunPendingTasks() { | 370 void RunPendingTasks() { |
| 371 base::RunLoop run_loop; | 371 base::RunLoop run_loop; |
| 372 run_loop.RunUntilIdle(); | 372 run_loop.RunUntilIdle(); |
| 373 } | 373 } |
| 374 | 374 |
| 375 base::MessageLoop message_loop_; | 375 base::MessageLoop message_loop_; |
| 376 Logger* logger_; | 376 Logger* logger_; |
| 377 std::unique_ptr<TestCastSocket> socket_; | 377 std::unique_ptr<TestCastSocket> socket_; |
| 378 CompleteHandler handler_; | 378 CompleteHandler handler_; |
| 379 std::unique_ptr<MockDelegate> delegate_; | 379 std::unique_ptr<MockCastSocketObserver> observer_; |
| 380 | 380 |
| 381 private: | 381 private: |
| 382 DISALLOW_COPY_AND_ASSIGN(CastSocketTest); | 382 DISALLOW_COPY_AND_ASSIGN(CastSocketTest); |
| 383 }; | 383 }; |
| 384 | 384 |
| 385 // Tests that the following connection flow works: | 385 // Tests that the following connection flow works: |
| 386 // - TCP connection succeeds (async) | 386 // - TCP connection succeeds (async) |
| 387 // - SSL connection succeeds (async) | 387 // - SSL connection succeeds (async) |
| 388 // - Cert is extracted successfully | 388 // - Cert is extracted successfully |
| 389 // - Challenge request is sent (async) | 389 // - Challenge request is sent (async) |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 426 | 426 |
| 427 socket_->SetupTcpConnect(net::ASYNC, net::OK); | 427 socket_->SetupTcpConnect(net::ASYNC, net::OK); |
| 428 socket_->SetupSslConnect(net::ASYNC, net::OK); | 428 socket_->SetupSslConnect(net::ASYNC, net::OK); |
| 429 | 429 |
| 430 CastMessage challenge_proto = CreateAuthChallenge(); | 430 CastMessage challenge_proto = CreateAuthChallenge(); |
| 431 EXPECT_CALL(*socket_->GetMockTransport(), | 431 EXPECT_CALL(*socket_->GetMockTransport(), |
| 432 SendMessage(EqualsProto(challenge_proto), _)) | 432 SendMessage(EqualsProto(challenge_proto), _)) |
| 433 .WillOnce(PostCompletionCallbackTask<1>(net::OK)); | 433 .WillOnce(PostCompletionCallbackTask<1>(net::OK)); |
| 434 EXPECT_CALL(*socket_->GetMockTransport(), Start()); | 434 EXPECT_CALL(*socket_->GetMockTransport(), Start()); |
| 435 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::TRANSPORT_ERROR)); | 435 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::TRANSPORT_ERROR)); |
| 436 socket_->Connect(std::move(delegate_), | 436 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 437 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 438 base::Unretained(&handler_))); | 437 base::Unretained(&handler_))); |
| 439 RunPendingTasks(); | 438 RunPendingTasks(); |
| 440 CastMessage mangled_auth_reply = CreateAuthReply(); | 439 CastMessage mangled_auth_reply = CreateAuthReply(); |
| 441 mangled_auth_reply.set_namespace_("BOGUS_NAMESPACE"); | 440 mangled_auth_reply.set_namespace_("BOGUS_NAMESPACE"); |
| 442 | 441 |
| 443 socket_->GetMockTransport()->current_delegate()->OnMessage( | 442 socket_->GetMockTransport()->current_delegate()->OnMessage( |
| 444 mangled_auth_reply); | 443 mangled_auth_reply); |
| 445 RunPendingTasks(); | 444 RunPendingTasks(); |
| 446 | 445 |
| 447 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 446 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 448 EXPECT_EQ(ChannelError::TRANSPORT_ERROR, socket_->error_state()); | 447 EXPECT_EQ(ChannelError::TRANSPORT_ERROR, socket_->error_state()); |
| 449 | 448 |
| 450 // Verifies that the CastSocket's resources were torn down during channel | 449 // Verifies that the CastSocket's resources were torn down during channel |
| 451 // close. (see http://crbug.com/504078) | 450 // close. (see http://crbug.com/504078) |
| 452 EXPECT_EQ(nullptr, socket_->transport()); | 451 EXPECT_EQ(nullptr, socket_->transport()); |
| 453 } | 452 } |
| 454 | 453 |
| 455 // Test connection error - TCP connect fails (async) | 454 // Test connection error - TCP connect fails (async) |
| 456 TEST_F(CastSocketTest, TestConnectTcpConnectErrorAsync) { | 455 TEST_F(CastSocketTest, TestConnectTcpConnectErrorAsync) { |
| 457 CreateCastSocketSecure(); | 456 CreateCastSocketSecure(); |
| 458 | 457 |
| 459 socket_->SetupTcpConnect(net::ASYNC, net::ERR_FAILED); | 458 socket_->SetupTcpConnect(net::ASYNC, net::ERR_FAILED); |
| 460 | 459 |
| 461 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_ERROR)); | 460 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_ERROR)); |
| 462 socket_->Connect(std::move(delegate_), | 461 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 463 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 464 base::Unretained(&handler_))); | 462 base::Unretained(&handler_))); |
| 465 RunPendingTasks(); | 463 RunPendingTasks(); |
| 466 | 464 |
| 467 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 465 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 468 EXPECT_EQ(ChannelError::CONNECT_ERROR, socket_->error_state()); | 466 EXPECT_EQ(ChannelError::CONNECT_ERROR, socket_->error_state()); |
| 469 } | 467 } |
| 470 | 468 |
| 471 // Test connection error - TCP connect fails (sync) | 469 // Test connection error - TCP connect fails (sync) |
| 472 TEST_F(CastSocketTest, TestConnectTcpConnectErrorSync) { | 470 TEST_F(CastSocketTest, TestConnectTcpConnectErrorSync) { |
| 473 CreateCastSocketSecure(); | 471 CreateCastSocketSecure(); |
| 474 | 472 |
| 475 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::ERR_FAILED); | 473 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::ERR_FAILED); |
| 476 | 474 |
| 477 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_ERROR)); | 475 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_ERROR)); |
| 478 socket_->Connect(std::move(delegate_), | 476 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 479 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 480 base::Unretained(&handler_))); | 477 base::Unretained(&handler_))); |
| 481 RunPendingTasks(); | 478 RunPendingTasks(); |
| 482 | 479 |
| 483 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 480 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 484 EXPECT_EQ(ChannelError::CONNECT_ERROR, socket_->error_state()); | 481 EXPECT_EQ(ChannelError::CONNECT_ERROR, socket_->error_state()); |
| 485 } | 482 } |
| 486 | 483 |
| 487 // Test connection error - timeout | 484 // Test connection error - timeout |
| 488 TEST_F(CastSocketTest, TestConnectTcpTimeoutError) { | 485 TEST_F(CastSocketTest, TestConnectTcpTimeoutError) { |
| 489 CreateCastSocketSecure(); | 486 CreateCastSocketSecure(); |
| 490 socket_->SetupTcpConnectUnresponsive(); | 487 socket_->SetupTcpConnectUnresponsive(); |
| 491 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_TIMEOUT)); | 488 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_TIMEOUT)); |
| 492 EXPECT_CALL(*delegate_, OnError(ChannelError::CONNECT_TIMEOUT)); | 489 EXPECT_CALL(*observer_, OnError(_, ChannelError::CONNECT_TIMEOUT)); |
| 493 socket_->Connect(std::move(delegate_), | 490 socket_->AddObserver("id", std::move(observer_)); |
| 494 base::Bind(&CompleteHandler::OnConnectComplete, | 491 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 495 base::Unretained(&handler_))); | 492 base::Unretained(&handler_))); |
| 496 RunPendingTasks(); | 493 RunPendingTasks(); |
| 497 | 494 |
| 498 EXPECT_EQ(ReadyState::CONNECTING, socket_->ready_state()); | 495 EXPECT_EQ(ReadyState::CONNECTING, socket_->ready_state()); |
| 499 EXPECT_EQ(ChannelError::NONE, socket_->error_state()); | 496 EXPECT_EQ(ChannelError::NONE, socket_->error_state()); |
| 500 socket_->TriggerTimeout(); | 497 socket_->TriggerTimeout(); |
| 501 RunPendingTasks(); | 498 RunPendingTasks(); |
| 502 | 499 |
| 503 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 500 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 504 EXPECT_EQ(ChannelError::CONNECT_TIMEOUT, socket_->error_state()); | 501 EXPECT_EQ(ChannelError::CONNECT_TIMEOUT, socket_->error_state()); |
| 505 } | 502 } |
| 506 | 503 |
| 507 // Test connection error - TCP socket returns timeout | 504 // Test connection error - TCP socket returns timeout |
| 508 TEST_F(CastSocketTest, TestConnectTcpSocketTimeoutError) { | 505 TEST_F(CastSocketTest, TestConnectTcpSocketTimeoutError) { |
| 509 CreateCastSocketSecure(); | 506 CreateCastSocketSecure(); |
| 510 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::ERR_CONNECTION_TIMED_OUT); | 507 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::ERR_CONNECTION_TIMED_OUT); |
| 511 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_TIMEOUT)); | 508 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_TIMEOUT)); |
| 512 EXPECT_CALL(*delegate_, OnError(ChannelError::CONNECT_TIMEOUT)); | 509 EXPECT_CALL(*observer_, OnError(_, ChannelError::CONNECT_TIMEOUT)); |
| 513 socket_->Connect(std::move(delegate_), | 510 socket_->AddObserver("id", std::move(observer_)); |
| 514 base::Bind(&CompleteHandler::OnConnectComplete, | 511 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 515 base::Unretained(&handler_))); | 512 base::Unretained(&handler_))); |
| 516 RunPendingTasks(); | 513 RunPendingTasks(); |
| 517 | 514 |
| 518 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 515 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 519 EXPECT_EQ(ChannelError::CONNECT_TIMEOUT, socket_->error_state()); | 516 EXPECT_EQ(ChannelError::CONNECT_TIMEOUT, socket_->error_state()); |
| 520 EXPECT_EQ(net::ERR_CONNECTION_TIMED_OUT, | 517 EXPECT_EQ(net::ERR_CONNECTION_TIMED_OUT, |
| 521 logger_->GetLastError(socket_->id()).net_return_value); | 518 logger_->GetLastError(socket_->id()).net_return_value); |
| 522 } | 519 } |
| 523 | 520 |
| 524 // Test connection error - SSL connect fails (async) | 521 // Test connection error - SSL connect fails (async) |
| 525 TEST_F(CastSocketTest, TestConnectSslConnectErrorAsync) { | 522 TEST_F(CastSocketTest, TestConnectSslConnectErrorAsync) { |
| 526 CreateCastSocketSecure(); | 523 CreateCastSocketSecure(); |
| 527 | 524 |
| 528 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); | 525 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); |
| 529 socket_->SetupSslConnect(net::SYNCHRONOUS, net::ERR_FAILED); | 526 socket_->SetupSslConnect(net::SYNCHRONOUS, net::ERR_FAILED); |
| 530 | 527 |
| 531 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::AUTHENTICATION_ERROR)); | 528 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::AUTHENTICATION_ERROR)); |
| 532 socket_->Connect(std::move(delegate_), | 529 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 533 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 534 base::Unretained(&handler_))); | 530 base::Unretained(&handler_))); |
| 535 RunPendingTasks(); | 531 RunPendingTasks(); |
| 536 | 532 |
| 537 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 533 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 538 EXPECT_EQ(ChannelError::AUTHENTICATION_ERROR, socket_->error_state()); | 534 EXPECT_EQ(ChannelError::AUTHENTICATION_ERROR, socket_->error_state()); |
| 539 } | 535 } |
| 540 | 536 |
| 541 // Test connection error - SSL connect fails (sync) | 537 // Test connection error - SSL connect fails (sync) |
| 542 TEST_F(CastSocketTest, TestConnectSslConnectErrorSync) { | 538 TEST_F(CastSocketTest, TestConnectSslConnectErrorSync) { |
| 543 CreateCastSocketSecure(); | 539 CreateCastSocketSecure(); |
| 544 | 540 |
| 545 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); | 541 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); |
| 546 socket_->SetupSslConnect(net::SYNCHRONOUS, net::ERR_FAILED); | 542 socket_->SetupSslConnect(net::SYNCHRONOUS, net::ERR_FAILED); |
| 547 | 543 |
| 548 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::AUTHENTICATION_ERROR)); | 544 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::AUTHENTICATION_ERROR)); |
| 549 socket_->Connect(std::move(delegate_), | 545 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 550 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 551 base::Unretained(&handler_))); | 546 base::Unretained(&handler_))); |
| 552 RunPendingTasks(); | 547 RunPendingTasks(); |
| 553 | 548 |
| 554 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 549 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 555 EXPECT_EQ(ChannelError::AUTHENTICATION_ERROR, socket_->error_state()); | 550 EXPECT_EQ(ChannelError::AUTHENTICATION_ERROR, socket_->error_state()); |
| 556 EXPECT_EQ(net::ERR_FAILED, | 551 EXPECT_EQ(net::ERR_FAILED, |
| 557 logger_->GetLastError(socket_->id()).net_return_value); | 552 logger_->GetLastError(socket_->id()).net_return_value); |
| 558 } | 553 } |
| 559 | 554 |
| 560 // Test connection error - SSL connect times out (sync) | 555 // Test connection error - SSL connect times out (sync) |
| 561 TEST_F(CastSocketTest, TestConnectSslConnectTimeoutSync) { | 556 TEST_F(CastSocketTest, TestConnectSslConnectTimeoutSync) { |
| 562 CreateCastSocketSecure(); | 557 CreateCastSocketSecure(); |
| 563 | 558 |
| 564 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); | 559 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); |
| 565 socket_->SetupSslConnect(net::SYNCHRONOUS, net::ERR_CONNECTION_TIMED_OUT); | 560 socket_->SetupSslConnect(net::SYNCHRONOUS, net::ERR_CONNECTION_TIMED_OUT); |
| 566 | 561 |
| 567 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_TIMEOUT)); | 562 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_TIMEOUT)); |
| 568 socket_->Connect(std::move(delegate_), | 563 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 569 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 570 base::Unretained(&handler_))); | 564 base::Unretained(&handler_))); |
| 571 RunPendingTasks(); | 565 RunPendingTasks(); |
| 572 | 566 |
| 573 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 567 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 574 EXPECT_EQ(ChannelError::CONNECT_TIMEOUT, socket_->error_state()); | 568 EXPECT_EQ(ChannelError::CONNECT_TIMEOUT, socket_->error_state()); |
| 575 EXPECT_EQ(net::ERR_CONNECTION_TIMED_OUT, | 569 EXPECT_EQ(net::ERR_CONNECTION_TIMED_OUT, |
| 576 logger_->GetLastError(socket_->id()).net_return_value); | 570 logger_->GetLastError(socket_->id()).net_return_value); |
| 577 } | 571 } |
| 578 | 572 |
| 579 // Test connection error - SSL connect times out (async) | 573 // Test connection error - SSL connect times out (async) |
| 580 TEST_F(CastSocketTest, TestConnectSslConnectTimeoutAsync) { | 574 TEST_F(CastSocketTest, TestConnectSslConnectTimeoutAsync) { |
| 581 CreateCastSocketSecure(); | 575 CreateCastSocketSecure(); |
| 582 | 576 |
| 583 socket_->SetupTcpConnect(net::ASYNC, net::OK); | 577 socket_->SetupTcpConnect(net::ASYNC, net::OK); |
| 584 socket_->SetupSslConnect(net::ASYNC, net::ERR_CONNECTION_TIMED_OUT); | 578 socket_->SetupSslConnect(net::ASYNC, net::ERR_CONNECTION_TIMED_OUT); |
| 585 | 579 |
| 586 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_TIMEOUT)); | 580 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CONNECT_TIMEOUT)); |
| 587 socket_->Connect(std::move(delegate_), | 581 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 588 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 589 base::Unretained(&handler_))); | 582 base::Unretained(&handler_))); |
| 590 RunPendingTasks(); | 583 RunPendingTasks(); |
| 591 | 584 |
| 592 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 585 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 593 EXPECT_EQ(ChannelError::CONNECT_TIMEOUT, socket_->error_state()); | 586 EXPECT_EQ(ChannelError::CONNECT_TIMEOUT, socket_->error_state()); |
| 594 } | 587 } |
| 595 | 588 |
| 596 // Test connection error - challenge send fails | 589 // Test connection error - challenge send fails |
| 597 TEST_F(CastSocketTest, TestConnectChallengeSendError) { | 590 TEST_F(CastSocketTest, TestConnectChallengeSendError) { |
| 598 CreateCastSocketSecure(); | 591 CreateCastSocketSecure(); |
| 599 socket_->SetupMockTransport(); | 592 socket_->SetupMockTransport(); |
| 600 | 593 |
| 601 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); | 594 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); |
| 602 socket_->SetupSslConnect(net::SYNCHRONOUS, net::OK); | 595 socket_->SetupSslConnect(net::SYNCHRONOUS, net::OK); |
| 603 EXPECT_CALL(*socket_->GetMockTransport(), | 596 EXPECT_CALL(*socket_->GetMockTransport(), |
| 604 SendMessage(EqualsProto(CreateAuthChallenge()), _)) | 597 SendMessage(EqualsProto(CreateAuthChallenge()), _)) |
| 605 .WillOnce(PostCompletionCallbackTask<1>(net::ERR_CONNECTION_RESET)); | 598 .WillOnce(PostCompletionCallbackTask<1>(net::ERR_CONNECTION_RESET)); |
| 606 | 599 |
| 607 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CAST_SOCKET_ERROR)); | 600 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CAST_SOCKET_ERROR)); |
| 608 socket_->Connect(std::move(delegate_), | 601 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 609 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 610 base::Unretained(&handler_))); | 602 base::Unretained(&handler_))); |
| 611 RunPendingTasks(); | 603 RunPendingTasks(); |
| 612 | 604 |
| 613 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 605 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 614 EXPECT_EQ(ChannelError::CAST_SOCKET_ERROR, socket_->error_state()); | 606 EXPECT_EQ(ChannelError::CAST_SOCKET_ERROR, socket_->error_state()); |
| 615 } | 607 } |
| 616 | 608 |
| 617 // Test connection error - connection is destroyed after the challenge is | 609 // Test connection error - connection is destroyed after the challenge is |
| 618 // sent, with the async result still lurking in the task queue. | 610 // sent, with the async result still lurking in the task queue. |
| 619 TEST_F(CastSocketTest, TestConnectDestroyedAfterChallengeSent) { | 611 TEST_F(CastSocketTest, TestConnectDestroyedAfterChallengeSent) { |
| 620 CreateCastSocketSecure(); | 612 CreateCastSocketSecure(); |
| 621 socket_->SetupMockTransport(); | 613 socket_->SetupMockTransport(); |
| 622 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); | 614 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); |
| 623 socket_->SetupSslConnect(net::SYNCHRONOUS, net::OK); | 615 socket_->SetupSslConnect(net::SYNCHRONOUS, net::OK); |
| 624 EXPECT_CALL(*socket_->GetMockTransport(), | 616 EXPECT_CALL(*socket_->GetMockTransport(), |
| 625 SendMessage(EqualsProto(CreateAuthChallenge()), _)) | 617 SendMessage(EqualsProto(CreateAuthChallenge()), _)) |
| 626 .WillOnce(PostCompletionCallbackTask<1>(net::ERR_CONNECTION_RESET)); | 618 .WillOnce(PostCompletionCallbackTask<1>(net::ERR_CONNECTION_RESET)); |
| 627 socket_->Connect(std::move(delegate_), | 619 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 628 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 629 base::Unretained(&handler_))); | 620 base::Unretained(&handler_))); |
| 630 socket_.reset(); | 621 socket_.reset(); |
| 631 RunPendingTasks(); | 622 RunPendingTasks(); |
| 632 } | 623 } |
| 633 | 624 |
| 634 // Test connection error - challenge reply receive fails | 625 // Test connection error - challenge reply receive fails |
| 635 TEST_F(CastSocketTest, TestConnectChallengeReplyReceiveError) { | 626 TEST_F(CastSocketTest, TestConnectChallengeReplyReceiveError) { |
| 636 CreateCastSocketSecure(); | 627 CreateCastSocketSecure(); |
| 637 socket_->SetupMockTransport(); | 628 socket_->SetupMockTransport(); |
| 638 | 629 |
| 639 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); | 630 socket_->SetupTcpConnect(net::SYNCHRONOUS, net::OK); |
| 640 socket_->SetupSslConnect(net::SYNCHRONOUS, net::OK); | 631 socket_->SetupSslConnect(net::SYNCHRONOUS, net::OK); |
| 641 EXPECT_CALL(*socket_->GetMockTransport(), | 632 EXPECT_CALL(*socket_->GetMockTransport(), |
| 642 SendMessage(EqualsProto(CreateAuthChallenge()), _)) | 633 SendMessage(EqualsProto(CreateAuthChallenge()), _)) |
| 643 .WillOnce(PostCompletionCallbackTask<1>(net::OK)); | 634 .WillOnce(PostCompletionCallbackTask<1>(net::OK)); |
| 644 socket_->AddReadResult(net::SYNCHRONOUS, net::ERR_FAILED); | 635 socket_->AddReadResult(net::SYNCHRONOUS, net::ERR_FAILED); |
| 645 EXPECT_CALL(*delegate_, OnError(ChannelError::CAST_SOCKET_ERROR)); | 636 EXPECT_CALL(*observer_, OnError(_, ChannelError::CAST_SOCKET_ERROR)); |
| 646 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CAST_SOCKET_ERROR)); | 637 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::CAST_SOCKET_ERROR)); |
| 647 EXPECT_CALL(*socket_->GetMockTransport(), Start()); | 638 EXPECT_CALL(*socket_->GetMockTransport(), Start()); |
| 648 socket_->Connect(std::move(delegate_), | 639 socket_->AddObserver("id", std::move(observer_)); |
| 649 base::Bind(&CompleteHandler::OnConnectComplete, | 640 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 650 base::Unretained(&handler_))); | 641 base::Unretained(&handler_))); |
| 651 RunPendingTasks(); | 642 RunPendingTasks(); |
| 652 socket_->GetMockTransport()->current_delegate()->OnError( | 643 socket_->GetMockTransport()->current_delegate()->OnError( |
| 653 ChannelError::CAST_SOCKET_ERROR); | 644 ChannelError::CAST_SOCKET_ERROR); |
| 654 RunPendingTasks(); | 645 RunPendingTasks(); |
| 655 | 646 |
| 656 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 647 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 657 EXPECT_EQ(ChannelError::CAST_SOCKET_ERROR, socket_->error_state()); | 648 EXPECT_EQ(ChannelError::CAST_SOCKET_ERROR, socket_->error_state()); |
| 658 } | 649 } |
| 659 | 650 |
| 660 TEST_F(CastSocketTest, TestConnectChallengeVerificationFails) { | 651 TEST_F(CastSocketTest, TestConnectChallengeVerificationFails) { |
| 661 CreateCastSocketSecure(); | 652 CreateCastSocketSecure(); |
| 662 socket_->SetupMockTransport(); | 653 socket_->SetupMockTransport(); |
| 663 socket_->SetupTcpConnect(net::ASYNC, net::OK); | 654 socket_->SetupTcpConnect(net::ASYNC, net::OK); |
| 664 socket_->SetupSslConnect(net::ASYNC, net::OK); | 655 socket_->SetupSslConnect(net::ASYNC, net::OK); |
| 665 socket_->SetVerifyChallengeResult(false); | 656 socket_->SetVerifyChallengeResult(false); |
| 666 | 657 |
| 667 EXPECT_CALL(*delegate_, OnError(ChannelError::AUTHENTICATION_ERROR)); | 658 EXPECT_CALL(*observer_, OnError(_, ChannelError::AUTHENTICATION_ERROR)); |
| 668 CastMessage challenge_proto = CreateAuthChallenge(); | 659 CastMessage challenge_proto = CreateAuthChallenge(); |
| 669 EXPECT_CALL(*socket_->GetMockTransport(), | 660 EXPECT_CALL(*socket_->GetMockTransport(), |
| 670 SendMessage(EqualsProto(challenge_proto), _)) | 661 SendMessage(EqualsProto(challenge_proto), _)) |
| 671 .WillOnce(PostCompletionCallbackTask<1>(net::OK)); | 662 .WillOnce(PostCompletionCallbackTask<1>(net::OK)); |
| 672 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::AUTHENTICATION_ERROR)); | 663 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::AUTHENTICATION_ERROR)); |
| 673 EXPECT_CALL(*socket_->GetMockTransport(), Start()); | 664 EXPECT_CALL(*socket_->GetMockTransport(), Start()); |
| 674 socket_->Connect(std::move(delegate_), | 665 socket_->AddObserver("id", std::move(observer_)); |
| 675 base::Bind(&CompleteHandler::OnConnectComplete, | 666 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 676 base::Unretained(&handler_))); | 667 base::Unretained(&handler_))); |
| 677 RunPendingTasks(); | 668 RunPendingTasks(); |
| 678 socket_->GetMockTransport()->current_delegate()->OnMessage(CreateAuthReply()); | 669 socket_->GetMockTransport()->current_delegate()->OnMessage(CreateAuthReply()); |
| 679 RunPendingTasks(); | 670 RunPendingTasks(); |
| 680 | 671 |
| 681 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); | 672 EXPECT_EQ(ReadyState::CLOSED, socket_->ready_state()); |
| 682 EXPECT_EQ(ChannelError::AUTHENTICATION_ERROR, socket_->error_state()); | 673 EXPECT_EQ(ChannelError::AUTHENTICATION_ERROR, socket_->error_state()); |
| 683 } | 674 } |
| 684 | 675 |
| 685 // Sends message data through an actual non-mocked CastTransport object, | 676 // Sends message data through an actual non-mocked CastTransport object, |
| (...skipping 15 matching lines...) Expand all Loading... |
| 701 EXPECT_TRUE(MessageFramer::Serialize(reply, &reply_str)); | 692 EXPECT_TRUE(MessageFramer::Serialize(reply, &reply_str)); |
| 702 socket_->AddReadResultForData(net::ASYNC, reply_str); | 693 socket_->AddReadResultForData(net::ASYNC, reply_str); |
| 703 socket_->AddReadResult(net::ASYNC, net::ERR_IO_PENDING); | 694 socket_->AddReadResult(net::ASYNC, net::ERR_IO_PENDING); |
| 704 | 695 |
| 705 CastMessage test_message = CreateTestMessage(); | 696 CastMessage test_message = CreateTestMessage(); |
| 706 std::string test_message_str; | 697 std::string test_message_str; |
| 707 EXPECT_TRUE(MessageFramer::Serialize(test_message, &test_message_str)); | 698 EXPECT_TRUE(MessageFramer::Serialize(test_message, &test_message_str)); |
| 708 socket_->AddWriteResultForData(net::ASYNC, test_message_str); | 699 socket_->AddWriteResultForData(net::ASYNC, test_message_str); |
| 709 | 700 |
| 710 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::NONE)); | 701 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::NONE)); |
| 711 socket_->Connect(std::move(delegate_), | 702 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 712 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 713 base::Unretained(&handler_))); | 703 base::Unretained(&handler_))); |
| 714 RunPendingTasks(); | 704 RunPendingTasks(); |
| 715 EXPECT_EQ(ReadyState::OPEN, socket_->ready_state()); | 705 EXPECT_EQ(ReadyState::OPEN, socket_->ready_state()); |
| 716 EXPECT_EQ(ChannelError::NONE, socket_->error_state()); | 706 EXPECT_EQ(ChannelError::NONE, socket_->error_state()); |
| 717 | 707 |
| 718 // Send the test message through a real transport object. | 708 // Send the test message through a real transport object. |
| 719 EXPECT_CALL(handler_, OnWriteComplete(net::OK)); | 709 EXPECT_CALL(handler_, OnWriteComplete(net::OK)); |
| 720 socket_->transport()->SendMessage( | 710 socket_->transport()->SendMessage( |
| 721 test_message, base::Bind(&CompleteHandler::OnWriteComplete, | 711 test_message, base::Bind(&CompleteHandler::OnWriteComplete, |
| 722 base::Unretained(&handler_))); | 712 base::Unretained(&handler_))); |
| (...skipping 21 matching lines...) Expand all Loading... |
| 744 EXPECT_TRUE(MessageFramer::Serialize(reply, &reply_str)); | 734 EXPECT_TRUE(MessageFramer::Serialize(reply, &reply_str)); |
| 745 socket_->AddReadResultForData(net::SYNCHRONOUS, reply_str); | 735 socket_->AddReadResultForData(net::SYNCHRONOUS, reply_str); |
| 746 socket_->AddReadResult(net::ASYNC, net::ERR_IO_PENDING); | 736 socket_->AddReadResult(net::ASYNC, net::ERR_IO_PENDING); |
| 747 | 737 |
| 748 CastMessage test_message = CreateTestMessage(); | 738 CastMessage test_message = CreateTestMessage(); |
| 749 std::string test_message_str; | 739 std::string test_message_str; |
| 750 EXPECT_TRUE(MessageFramer::Serialize(test_message, &test_message_str)); | 740 EXPECT_TRUE(MessageFramer::Serialize(test_message, &test_message_str)); |
| 751 socket_->AddWriteResultForData(net::SYNCHRONOUS, test_message_str); | 741 socket_->AddWriteResultForData(net::SYNCHRONOUS, test_message_str); |
| 752 | 742 |
| 753 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::NONE)); | 743 EXPECT_CALL(handler_, OnConnectComplete(ChannelError::NONE)); |
| 754 socket_->Connect(std::move(delegate_), | 744 socket_->Connect(base::Bind(&CompleteHandler::OnConnectComplete, |
| 755 base::Bind(&CompleteHandler::OnConnectComplete, | |
| 756 base::Unretained(&handler_))); | 745 base::Unretained(&handler_))); |
| 757 RunPendingTasks(); | 746 RunPendingTasks(); |
| 758 EXPECT_EQ(ReadyState::OPEN, socket_->ready_state()); | 747 EXPECT_EQ(ReadyState::OPEN, socket_->ready_state()); |
| 759 EXPECT_EQ(ChannelError::NONE, socket_->error_state()); | 748 EXPECT_EQ(ChannelError::NONE, socket_->error_state()); |
| 760 | 749 |
| 761 // Send the test message through a real transport object. | 750 // Send the test message through a real transport object. |
| 762 EXPECT_CALL(handler_, OnWriteComplete(net::OK)); | 751 EXPECT_CALL(handler_, OnWriteComplete(net::OK)); |
| 763 socket_->transport()->SendMessage( | 752 socket_->transport()->SendMessage( |
| 764 test_message, base::Bind(&CompleteHandler::OnWriteComplete, | 753 test_message, base::Bind(&CompleteHandler::OnWriteComplete, |
| 765 base::Unretained(&handler_))); | 754 base::Unretained(&handler_))); |
| 766 RunPendingTasks(); | 755 RunPendingTasks(); |
| 767 | 756 |
| 768 EXPECT_EQ(ReadyState::OPEN, socket_->ready_state()); | 757 EXPECT_EQ(ReadyState::OPEN, socket_->ready_state()); |
| 769 EXPECT_EQ(ChannelError::NONE, socket_->error_state()); | 758 EXPECT_EQ(ChannelError::NONE, socket_->error_state()); |
| 770 } | 759 } |
| 771 | 760 |
| 761 TEST_F(CastSocketTest, TestObservers) { |
| 762 CreateCastSocketSecure(); |
| 763 std::string id1 = "id1"; |
| 764 std::string id2 = "id2"; |
| 765 EXPECT_FALSE(socket_->HasObserver(id1)); |
| 766 EXPECT_FALSE(socket_->HasObserver(id2)); |
| 767 |
| 768 // Test AddObserever |
| 769 MockCastSocketObserver* observer1 = new MockCastSocketObserver(); |
| 770 MockCastSocketObserver* observer2 = new MockCastSocketObserver(); |
| 771 socket_->AddObserver(id1, base::WrapUnique(observer1)); |
| 772 EXPECT_TRUE(socket_->HasObserver(id1)); |
| 773 socket_->AddObserver(id2, base::WrapUnique(observer2)); |
| 774 EXPECT_TRUE(socket_->HasObserver(id2)); |
| 775 |
| 776 // Test notify observers |
| 777 EXPECT_CALL(*observer1, |
| 778 OnError(_, cast_channel::ChannelError::CONNECT_ERROR)); |
| 779 EXPECT_CALL(*observer2, |
| 780 OnError(_, cast_channel::ChannelError::CONNECT_ERROR)); |
| 781 CastSocketImpl::CastSocketMessageDelegate delegate(socket_.get()); |
| 782 delegate.OnError(cast_channel::ChannelError::CONNECT_ERROR); |
| 783 } |
| 784 |
| 772 } // namespace cast_channel | 785 } // namespace cast_channel |
| OLD | NEW |