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 <stddef.h> | 5 #include <stddef.h> |
6 #include <string> | 6 #include <string> |
7 | 7 |
8 #include "base/callback_helpers.h" | 8 #include "base/callback_helpers.h" |
9 #include "blimp/common/proto/blimp_message.pb.h" | 9 #include "blimp/common/proto/blimp_message.pb.h" |
10 #include "blimp/net/blimp_message_pump.h" | 10 #include "blimp/net/blimp_message_pump.h" |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
43 protected: | 43 protected: |
44 scoped_ptr<BlimpMessage> message1_; | 44 scoped_ptr<BlimpMessage> message1_; |
45 scoped_ptr<BlimpMessage> message2_; | 45 scoped_ptr<BlimpMessage> message2_; |
46 | 46 |
47 testing::StrictMock<MockPacketReader> reader_; | 47 testing::StrictMock<MockPacketReader> reader_; |
48 testing::StrictMock<MockConnectionErrorObserver> error_observer_; | 48 testing::StrictMock<MockConnectionErrorObserver> error_observer_; |
49 testing::StrictMock<MockBlimpMessageProcessor> receiver_; | 49 testing::StrictMock<MockBlimpMessageProcessor> receiver_; |
50 scoped_ptr<BlimpMessagePump> message_pump_; | 50 scoped_ptr<BlimpMessagePump> message_pump_; |
51 }; | 51 }; |
52 | 52 |
53 // Reader completes reading one packet synchronously. | 53 // Reader completes reading one packet asynchronously. |
54 TEST_F(BlimpMessagePumpTest, SyncPacketRead) { | 54 TEST_F(BlimpMessagePumpTest, ReadPacket) { |
55 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message1_), _)); | 55 net::CompletionCallback read_packet_cb; |
| 56 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)); |
56 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) | 57 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) |
57 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), | 58 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), |
58 Return(message1_->ByteSize()))); | 59 SetBufferOffset<0>(message1_->ByteSize()), |
59 message_pump_->SetMessageProcessor(&receiver_); | 60 SaveArg<1>(&read_packet_cb))) |
60 } | 61 .RetiresOnSaturation(); |
61 | |
62 // Reader completes reading two packets synchronously. | |
63 TEST_F(BlimpMessagePumpTest, SyncTwoPacketsRead) { | |
64 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) | |
65 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), | |
66 Return(message1_->ByteSize()))) | |
67 .WillOnce(DoAll(FillBufferFromMessage<0>(message2_.get()), | |
68 Return(message2_->ByteSize()))); | |
69 net::CompletionCallback process_msg_cb; | |
70 { | |
71 InSequence s; | |
72 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message1_), _)) | |
73 .WillOnce(SaveArg<1>(&process_msg_cb)) | |
74 .RetiresOnSaturation(); | |
75 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message2_), _)); | |
76 } | |
77 message_pump_->SetMessageProcessor(&receiver_); | |
78 | |
79 // Trigger next packet read | |
80 process_msg_cb.Run(net::OK); | |
81 } | |
82 | |
83 // Reader completes reading one packet asynchronously. | |
84 TEST_F(BlimpMessagePumpTest, AsyncPacketRead) { | |
85 net::CompletionCallback read_packet_cb; | |
86 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) | |
87 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), | |
88 SaveArg<1>(&read_packet_cb), Return(net::ERR_IO_PENDING))) | |
89 .WillOnce(Return(net::ERR_IO_PENDING)); | |
90 net::CompletionCallback process_msg_cb; | 62 net::CompletionCallback process_msg_cb; |
91 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message1_), _)) | 63 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message1_), _)) |
92 .WillOnce(SaveArg<1>(&process_msg_cb)); | 64 .WillOnce(SaveArg<1>(&process_msg_cb)); |
93 message_pump_->SetMessageProcessor(&receiver_); | 65 message_pump_->SetMessageProcessor(&receiver_); |
94 read_packet_cb.Run(message1_->ByteSize()); | 66 ASSERT_FALSE(read_packet_cb.is_null()); |
| 67 base::ResetAndReturn(&read_packet_cb).Run(net::OK); |
95 process_msg_cb.Run(net::OK); | 68 process_msg_cb.Run(net::OK); |
96 } | 69 } |
97 | 70 |
98 // Reader completes reading two packets asynchronously. | 71 // Reader completes reading two packets asynchronously. |
99 TEST_F(BlimpMessagePumpTest, AsyncTwoPacketsRead) { | 72 TEST_F(BlimpMessagePumpTest, ReadTwoPackets) { |
100 net::CompletionCallback read_packet_cb; | 73 net::CompletionCallback read_packet_cb; |
101 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) | 74 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) |
102 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), | 75 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), |
103 SaveArg<1>(&read_packet_cb), Return(net::ERR_IO_PENDING))) | 76 SetBufferOffset<0>(message1_->ByteSize()), |
| 77 SaveArg<1>(&read_packet_cb))) |
104 .WillOnce(DoAll(FillBufferFromMessage<0>(message2_.get()), | 78 .WillOnce(DoAll(FillBufferFromMessage<0>(message2_.get()), |
105 SaveArg<1>(&read_packet_cb), | 79 SetBufferOffset<0>(message2_->ByteSize()), |
106 Return(net::ERR_IO_PENDING))); | 80 SaveArg<1>(&read_packet_cb))); |
107 net::CompletionCallback process_msg_cb; | 81 net::CompletionCallback process_msg_cb; |
108 { | 82 { |
109 InSequence s; | 83 InSequence s; |
110 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message1_), _)) | 84 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message1_), _)) |
111 .WillOnce(SaveArg<1>(&process_msg_cb)) | 85 .WillOnce(SaveArg<1>(&process_msg_cb)) |
112 .RetiresOnSaturation(); | 86 .RetiresOnSaturation(); |
113 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message2_), _)); | 87 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message2_), _)); |
114 } | 88 } |
115 message_pump_->SetMessageProcessor(&receiver_); | 89 message_pump_->SetMessageProcessor(&receiver_); |
116 read_packet_cb.Run(message1_->ByteSize()); | 90 ASSERT_FALSE(read_packet_cb.is_null()); |
| 91 base::ResetAndReturn(&read_packet_cb).Run(net::OK); |
117 | 92 |
118 // Trigger next packet read | 93 // Trigger next packet read |
119 process_msg_cb.Run(net::OK); | 94 process_msg_cb.Run(net::OK); |
120 read_packet_cb.Run(message2_->ByteSize()); | 95 ASSERT_FALSE(read_packet_cb.is_null()); |
| 96 base::ResetAndReturn(&read_packet_cb).Run(net::OK); |
121 } | 97 } |
122 | 98 |
123 // Reader completes reading two packets asynchronously. | 99 // Reader completes reading two packets asynchronously. |
124 // The first read succeeds, and the second fails. | 100 // The first read succeeds, and the second fails. |
125 TEST_F(BlimpMessagePumpTest, AsyncTwoPacketsReadWithError) { | 101 TEST_F(BlimpMessagePumpTest, ReadTwoPacketsWithError) { |
| 102 net::CompletionCallback process_msg_cb; |
126 net::CompletionCallback read_packet_cb; | 103 net::CompletionCallback read_packet_cb; |
127 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) | 104 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) |
128 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), | 105 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), |
129 SaveArg<1>(&read_packet_cb), Return(net::ERR_IO_PENDING))) | 106 SetBufferOffset<0>(message1_->ByteSize()), |
| 107 SaveArg<1>(&read_packet_cb))) |
130 .WillOnce(DoAll(FillBufferFromMessage<0>(message2_.get()), | 108 .WillOnce(DoAll(FillBufferFromMessage<0>(message2_.get()), |
131 SaveArg<1>(&read_packet_cb), | 109 SetBufferOffset<0>(message2_->ByteSize()), |
132 Return(net::ERR_IO_PENDING))); | 110 SaveArg<1>(&read_packet_cb))); |
133 net::CompletionCallback process_msg_cb; | 111 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message1_), _)) |
134 { | 112 .WillOnce(SaveArg<1>(&process_msg_cb)); |
135 InSequence s; | 113 EXPECT_CALL(error_observer_, OnConnectionError(net::ERR_FAILED)); |
136 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message1_), _)) | 114 |
137 .WillOnce(SaveArg<1>(&process_msg_cb)); | |
138 EXPECT_CALL(error_observer_, OnConnectionError(net::ERR_FAILED)); | |
139 } | |
140 message_pump_->SetMessageProcessor(&receiver_); | 115 message_pump_->SetMessageProcessor(&receiver_); |
141 read_packet_cb.Run(message1_->ByteSize()); | 116 ASSERT_FALSE(read_packet_cb.is_null()); |
| 117 base::ResetAndReturn(&read_packet_cb).Run(net::OK); |
142 | 118 |
143 // Trigger next packet read | 119 // Trigger next packet read |
144 process_msg_cb.Run(net::OK); | 120 process_msg_cb.Run(net::OK); |
145 read_packet_cb.Run(net::ERR_FAILED); | 121 ASSERT_FALSE(read_packet_cb.is_null()); |
| 122 base::ResetAndReturn(&read_packet_cb).Run(net::ERR_FAILED); |
146 } | 123 } |
147 | 124 |
148 // Reader completes reading one packet synchronously, but packet is invalid | 125 // Reader completes reading one packet synchronously, but packet is invalid |
149 TEST_F(BlimpMessagePumpTest, InvalidPacket) { | 126 TEST_F(BlimpMessagePumpTest, InvalidPacket) { |
| 127 net::CompletionCallback read_packet_cb; |
150 std::string test_msg("msg"); | 128 std::string test_msg("msg"); |
151 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) | 129 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) |
152 .WillOnce(DoAll(FillBufferFromString<0>(test_msg), Return(1))); | 130 .WillOnce(DoAll(FillBufferFromString<0>(test_msg), |
| 131 SetBufferOffset<0>(test_msg.size()), |
| 132 SaveArg<1>(&read_packet_cb))); |
153 EXPECT_CALL(error_observer_, OnConnectionError(net::ERR_FAILED)); | 133 EXPECT_CALL(error_observer_, OnConnectionError(net::ERR_FAILED)); |
154 message_pump_->SetMessageProcessor(&receiver_); | |
155 } | |
156 | |
157 TEST_F(BlimpMessagePumpTest, ClearMessageProcessorAfterRead) { | |
158 net::CompletionCallback read_packet_cb; | |
159 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) | |
160 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), | |
161 SaveArg<1>(&read_packet_cb), | |
162 Return(net::ERR_IO_PENDING))); | |
163 net::CompletionCallback process_msg_cb; | |
164 EXPECT_CALL(receiver_, MockableProcessMessage(EqualsProto(*message1_), _)) | |
165 .WillOnce(SaveArg<1>(&process_msg_cb)); | |
166 | 134 |
167 message_pump_->SetMessageProcessor(&receiver_); | 135 message_pump_->SetMessageProcessor(&receiver_); |
168 base::ResetAndReturn(&read_packet_cb).Run(message1_->ByteSize()); | 136 ASSERT_FALSE(read_packet_cb.is_null()); |
169 | 137 base::ResetAndReturn(&read_packet_cb).Run(net::OK); |
170 message_pump_->SetMessageProcessor(nullptr); | |
171 | |
172 // Completing message processing will not trigger next packet read. | |
173 base::ResetAndReturn(&process_msg_cb).Run(net::OK); | |
174 } | |
175 | |
176 TEST_F(BlimpMessagePumpTest, ClearMessageProcessorDuringRead) { | |
177 net::CompletionCallback read_packet_cb; | |
178 EXPECT_CALL(reader_, ReadPacket(NotNull(), _)) | |
179 .WillOnce(DoAll(FillBufferFromMessage<0>(message1_.get()), | |
180 SaveArg<1>(&read_packet_cb), | |
181 Return(net::ERR_IO_PENDING))); | |
182 | |
183 // Receiver will not get any message. | |
184 message_pump_->SetMessageProcessor(&receiver_); | |
185 message_pump_->SetMessageProcessor(nullptr); | |
186 base::ResetAndReturn(&read_packet_cb).Run(message1_->ByteSize()); | |
187 } | 138 } |
188 | 139 |
189 } // namespace | 140 } // namespace |
190 | 141 |
191 } // namespace blimp | 142 } // namespace blimp |
OLD | NEW |