OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "blimp/net/client_connection_manager.h" | 5 #include "blimp/net/client_connection_manager.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | |
9 #include <string> | 8 #include <string> |
| 9 #include <utility> |
10 | 10 |
11 #include "base/callback_helpers.h" | 11 #include "base/callback_helpers.h" |
12 #include "base/memory/ptr_util.h" | 12 #include "base/memory/ptr_util.h" |
13 #include "base/message_loop/message_loop.h" | 13 #include "base/message_loop/message_loop.h" |
14 #include "blimp/common/create_blimp_message.h" | 14 #include "blimp/common/create_blimp_message.h" |
15 #include "blimp/common/proto/blimp_message.pb.h" | 15 #include "blimp/common/proto/blimp_message.pb.h" |
16 #include "blimp/common/protocol_version.h" | 16 #include "blimp/common/protocol_version.h" |
17 #include "blimp/net/blimp_connection.h" | |
18 #include "blimp/net/blimp_transport.h" | |
19 #include "blimp/net/test_common.h" | 17 #include "blimp/net/test_common.h" |
20 #include "net/base/completion_callback.h" | 18 #include "net/base/completion_callback.h" |
21 #include "net/base/net_errors.h" | 19 #include "net/base/net_errors.h" |
22 #include "net/base/test_completion_callback.h" | 20 #include "net/base/test_completion_callback.h" |
23 #include "testing/gmock/include/gmock/gmock.h" | 21 #include "testing/gmock/include/gmock/gmock.h" |
24 #include "testing/gtest/include/gtest/gtest.h" | 22 #include "testing/gtest/include/gtest/gtest.h" |
25 | 23 |
26 using testing::_; | 24 using testing::_; |
27 using testing::Eq; | 25 using testing::Eq; |
28 using testing::Return; | 26 using testing::Return; |
29 using testing::SaveArg; | 27 using testing::SaveArg; |
30 | 28 |
31 namespace blimp { | 29 namespace blimp { |
32 namespace { | 30 namespace { |
33 const char kDummyClientToken[] = "dummy-client-token"; | 31 const char kDummyClientToken[] = "dummy-client-token"; |
34 } // namespace | 32 } // namespace |
35 | 33 |
36 class ClientConnectionManagerTest : public testing::Test { | 34 class ClientConnectionManagerTest : public testing::Test { |
37 public: | 35 public: |
38 ClientConnectionManagerTest() | 36 ClientConnectionManagerTest() |
39 : manager_(new ClientConnectionManager(&connection_handler_)), | 37 : manager_(new ClientConnectionManager(&connection_handler_)), |
40 transport1_(new testing::StrictMock<MockTransport>), | 38 transport1_(new testing::StrictMock<MockTransport>), |
41 transport2_(new testing::StrictMock<MockTransport>), | 39 transport2_(new testing::StrictMock<MockTransport>), |
42 reader_(new MockPacketReader), | 40 reader_(new testing::StrictMock<MockPacketReader>), |
43 writer_(new MockPacketWriter), | 41 writer_(new testing::StrictMock<MockPacketWriter>), |
44 connection_(new BlimpConnection(base::WrapUnique(reader_), | |
45 base::WrapUnique(writer_))), | |
46 start_connection_message_( | 42 start_connection_message_( |
47 CreateStartConnectionMessage(kDummyClientToken, kProtocolVersion)) { | 43 CreateStartConnectionMessage(kDummyClientToken, kProtocolVersion)) { |
48 manager_->set_client_token(kDummyClientToken); | 44 manager_->set_client_token(kDummyClientToken); |
49 } | 45 } |
50 | 46 |
51 ~ClientConnectionManagerTest() override {} | 47 ~ClientConnectionManagerTest() override {} |
52 | 48 |
53 protected: | 49 protected: |
54 base::MessageLoop message_loop_; | 50 base::MessageLoop message_loop_; |
55 testing::StrictMock<MockConnectionHandler> connection_handler_; | 51 testing::StrictMock<MockConnectionHandler> connection_handler_; |
56 std::unique_ptr<ClientConnectionManager> manager_; | 52 std::unique_ptr<ClientConnectionManager> manager_; |
57 std::unique_ptr<testing::StrictMock<MockTransport>> transport1_; | 53 std::unique_ptr<testing::StrictMock<MockTransport>> transport1_; |
58 std::unique_ptr<testing::StrictMock<MockTransport>> transport2_; | 54 std::unique_ptr<testing::StrictMock<MockTransport>> transport2_; |
59 MockPacketReader* reader_; | 55 std::unique_ptr<MockPacketReader> reader_; |
60 MockPacketWriter* writer_; | 56 std::unique_ptr<MockPacketWriter> writer_; |
61 std::unique_ptr<BlimpConnection> connection_; | |
62 std::unique_ptr<BlimpMessage> start_connection_message_; | 57 std::unique_ptr<BlimpMessage> start_connection_message_; |
63 }; | 58 }; |
64 | 59 |
65 // The 1st transport connects, and the 2nd transport is not used. | 60 // The 1st transport connects, and the 2nd transport is not used. |
66 TEST_F(ClientConnectionManagerTest, FirstTransportConnects) { | 61 TEST_F(ClientConnectionManagerTest, FirstTransportConnects) { |
67 net::CompletionCallback write_cb; | 62 net::CompletionCallback write_cb; |
68 net::CompletionCallback connect_cb_1; | 63 net::CompletionCallback connect_cb_1; |
69 EXPECT_CALL(*transport1_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_1)); | 64 EXPECT_CALL(*transport1_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_1)); |
70 EXPECT_CALL(connection_handler_, HandleConnectionPtr(Eq(connection_.get()))); | 65 EXPECT_CALL(connection_handler_, HandleConnectionPtr(_)); |
71 EXPECT_CALL(*writer_, | 66 EXPECT_CALL(*writer_, |
72 WritePacket(BufferEqualsProto(*start_connection_message_), _)) | 67 WritePacket(BufferEqualsProto(*start_connection_message_), _)) |
73 .WillOnce(SaveArg<1>(&write_cb)); | 68 .WillOnce(SaveArg<1>(&write_cb)); |
74 EXPECT_CALL(*transport1_, TakeConnectionPtr()) | |
75 .WillOnce(Return(connection_.release())); | |
76 | 69 |
77 ASSERT_TRUE(connect_cb_1.is_null()); | 70 EXPECT_CALL(*transport1_, TakeMessagePortPtr()) |
| 71 .WillOnce( |
| 72 Return(new MessagePort(std::move(reader_), std::move(writer_)))); |
| 73 |
| 74 EXPECT_TRUE(connect_cb_1.is_null()); |
78 manager_->AddTransport(std::move(transport1_)); | 75 manager_->AddTransport(std::move(transport1_)); |
79 manager_->AddTransport(std::move(transport2_)); | 76 manager_->AddTransport(std::move(transport2_)); |
80 manager_->Connect(); | 77 manager_->Connect(); |
81 ASSERT_FALSE(connect_cb_1.is_null()); | 78 EXPECT_FALSE(connect_cb_1.is_null()); |
82 base::ResetAndReturn(&connect_cb_1).Run(net::OK); | 79 base::ResetAndReturn(&connect_cb_1).Run(net::OK); |
83 base::ResetAndReturn(&write_cb).Run(net::OK); | 80 base::ResetAndReturn(&write_cb).Run(net::OK); |
84 } | 81 } |
85 | 82 |
86 // The 1st transport fails to connect, and the 2nd transport connects. | 83 // The 1st transport fails to connect, and the 2nd transport connects. |
87 TEST_F(ClientConnectionManagerTest, SecondTransportConnects) { | 84 TEST_F(ClientConnectionManagerTest, SecondTransportConnects) { |
88 net::CompletionCallback write_cb; | 85 net::CompletionCallback write_cb; |
89 net::CompletionCallback connect_cb_1; | 86 net::CompletionCallback connect_cb_1; |
90 EXPECT_CALL(*transport1_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_1)); | 87 EXPECT_CALL(*transport1_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_1)); |
91 net::CompletionCallback connect_cb_2; | 88 net::CompletionCallback connect_cb_2; |
92 EXPECT_CALL(*transport2_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_2)); | 89 EXPECT_CALL(*transport2_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_2)); |
93 EXPECT_CALL(*writer_, | 90 EXPECT_CALL(*writer_, |
94 WritePacket(BufferEqualsProto(*start_connection_message_), _)) | 91 WritePacket(BufferEqualsProto(*start_connection_message_), _)) |
95 .WillOnce(SaveArg<1>(&write_cb)); | 92 .WillOnce(SaveArg<1>(&write_cb)); |
96 EXPECT_CALL(connection_handler_, HandleConnectionPtr(Eq(connection_.get()))); | 93 EXPECT_CALL(connection_handler_, HandleConnectionPtr(_)); |
97 EXPECT_CALL(*transport2_, TakeConnectionPtr()) | 94 EXPECT_CALL(*transport2_, TakeMessagePortPtr()) |
98 .WillOnce(Return(connection_.release())); | 95 .WillOnce( |
| 96 Return(new MessagePort(std::move(reader_), std::move(writer_)))); |
99 | 97 |
100 ASSERT_TRUE(connect_cb_1.is_null()); | 98 EXPECT_TRUE(connect_cb_1.is_null()); |
101 ASSERT_TRUE(connect_cb_2.is_null()); | 99 EXPECT_TRUE(connect_cb_2.is_null()); |
102 manager_->AddTransport(std::move(transport1_)); | 100 manager_->AddTransport(std::move(transport1_)); |
103 manager_->AddTransport(std::move(transport2_)); | 101 manager_->AddTransport(std::move(transport2_)); |
104 manager_->Connect(); | 102 manager_->Connect(); |
105 ASSERT_FALSE(connect_cb_1.is_null()); | 103 EXPECT_FALSE(connect_cb_1.is_null()); |
106 base::ResetAndReturn(&connect_cb_1).Run(net::ERR_FAILED); | 104 base::ResetAndReturn(&connect_cb_1).Run(net::ERR_FAILED); |
107 ASSERT_FALSE(connect_cb_2.is_null()); | 105 EXPECT_FALSE(connect_cb_2.is_null()); |
108 base::ResetAndReturn(&connect_cb_2).Run(net::OK); | 106 base::ResetAndReturn(&connect_cb_2).Run(net::OK); |
109 base::ResetAndReturn(&write_cb).Run(net::OK); | 107 base::ResetAndReturn(&write_cb).Run(net::OK); |
110 } | 108 } |
111 | 109 |
112 // Both transports fail to connect. | 110 // Both transports fail to connect. |
113 TEST_F(ClientConnectionManagerTest, BothTransportsFailToConnect) { | 111 TEST_F(ClientConnectionManagerTest, BothTransportsFailToConnect) { |
114 net::CompletionCallback connect_cb_1; | 112 net::CompletionCallback connect_cb_1; |
115 EXPECT_CALL(*transport1_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_1)); | 113 EXPECT_CALL(*transport1_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_1)); |
116 net::CompletionCallback connect_cb_2; | 114 net::CompletionCallback connect_cb_2; |
117 EXPECT_CALL(*transport2_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_2)); | 115 EXPECT_CALL(*transport2_, Connect(_)).WillOnce(SaveArg<0>(&connect_cb_2)); |
118 | 116 |
119 ASSERT_TRUE(connect_cb_1.is_null()); | 117 EXPECT_TRUE(connect_cb_1.is_null()); |
120 ASSERT_TRUE(connect_cb_2.is_null()); | 118 EXPECT_TRUE(connect_cb_2.is_null()); |
121 manager_->AddTransport(std::move(transport1_)); | 119 manager_->AddTransport(std::move(transport1_)); |
122 manager_->AddTransport(std::move(transport2_)); | 120 manager_->AddTransport(std::move(transport2_)); |
123 manager_->Connect(); | 121 manager_->Connect(); |
124 ASSERT_FALSE(connect_cb_1.is_null()); | 122 EXPECT_FALSE(connect_cb_1.is_null()); |
125 ASSERT_TRUE(connect_cb_2.is_null()); | 123 EXPECT_TRUE(connect_cb_2.is_null()); |
126 base::ResetAndReturn(&connect_cb_1).Run(net::ERR_FAILED); | 124 base::ResetAndReturn(&connect_cb_1).Run(net::ERR_FAILED); |
127 ASSERT_FALSE(connect_cb_2.is_null()); | 125 EXPECT_FALSE(connect_cb_2.is_null()); |
128 base::ResetAndReturn(&connect_cb_2).Run(net::ERR_FAILED); | 126 base::ResetAndReturn(&connect_cb_2).Run(net::ERR_FAILED); |
129 } | 127 } |
130 | 128 |
131 } // namespace blimp | 129 } // namespace blimp |
OLD | NEW |