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 "google_apis/gcm/engine/mcs_client.h" | 5 #include "google_apis/gcm/engine/mcs_client.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/files/scoped_temp_dir.h" | 8 #include "base/files/scoped_temp_dir.h" |
9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
10 #include "base/run_loop.h" | 10 #include "base/run_loop.h" |
(...skipping 345 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
356 kLoginRequestTag, | 356 kLoginRequestTag, |
357 BuildLoginRequest(kAndroidId, kSecurityToken, ""). | 357 BuildLoginRequest(kAndroidId, kSecurityToken, ""). |
358 PassAs<const google::protobuf::MessageLite>())); | 358 PassAs<const google::protobuf::MessageLite>())); |
359 // The second (re)send. | 359 // The second (re)send. |
360 MCSMessage message2(BuildDataMessage( | 360 MCSMessage message2(BuildDataMessage( |
361 "from", "category", "X", 1, "1", kTTLValue, 1, kTTLValue - 1, "", 0)); | 361 "from", "category", "X", 1, "1", kTTLValue, 1, kTTLValue - 1, "", 0)); |
362 GetFakeHandler()->ExpectOutgoingMessage(message2); | 362 GetFakeHandler()->ExpectOutgoingMessage(message2); |
363 mcs_client()->SendMessage(message); | 363 mcs_client()->SendMessage(message); |
364 PumpLoop(); // Wait for the queuing to happen. | 364 PumpLoop(); // Wait for the queuing to happen. |
365 EXPECT_EQ(MCSClient::QUEUED, message_send_status()); | 365 EXPECT_EQ(MCSClient::QUEUED, message_send_status()); |
| 366 EXPECT_EQ("X", sent_message_id()); |
366 EXPECT_FALSE(GetFakeHandler()->AllOutgoingMessagesReceived()); | 367 EXPECT_FALSE(GetFakeHandler()->AllOutgoingMessagesReceived()); |
367 GetFakeHandler()->set_fail_send(false); | 368 GetFakeHandler()->set_fail_send(false); |
368 clock()->Advance(base::TimeDelta::FromSeconds(kTTLValue - 1)); | 369 clock()->Advance(base::TimeDelta::FromSeconds(kTTLValue - 1)); |
369 connection_factory()->Connect(); | 370 connection_factory()->Connect(); |
370 WaitForMCSEvent(); // Wait for the login to finish. | 371 WaitForMCSEvent(); // Wait for the login to finish. |
371 PumpLoop(); // Wait for the send to happen. | 372 PumpLoop(); // Wait for the send to happen. |
| 373 |
| 374 // Receive the ack. |
| 375 scoped_ptr<mcs_proto::IqStanza> ack = BuildStreamAck(); |
| 376 ack->set_last_stream_id_received(2); |
| 377 GetFakeHandler()->ReceiveMessage( |
| 378 MCSMessage(kIqStanzaTag, |
| 379 ack.PassAs<const google::protobuf::MessageLite>())); |
| 380 WaitForMCSEvent(); |
| 381 |
| 382 EXPECT_EQ(MCSClient::SENT, message_send_status()); |
| 383 EXPECT_EQ("X", sent_message_id()); |
372 EXPECT_TRUE(GetFakeHandler()->AllOutgoingMessagesReceived()); | 384 EXPECT_TRUE(GetFakeHandler()->AllOutgoingMessagesReceived()); |
373 } | 385 } |
374 | 386 |
375 // Send a message with RMQ support without receiving an acknowledgement. On | 387 // Send a message with RMQ support without receiving an acknowledgement. On |
376 // restart the message should be resent. | 388 // restart the message should be resent. |
377 TEST_F(MCSClientTest, SendMessageRMQOnRestart) { | 389 TEST_F(MCSClientTest, SendMessageRMQOnRestart) { |
378 BuildMCSClient(); | 390 BuildMCSClient(); |
379 InitializeClient(); | 391 InitializeClient(); |
380 LoginClient(std::vector<std::string>()); | 392 LoginClient(std::vector<std::string>()); |
381 GetFakeHandler()->set_fail_send(true); | 393 GetFakeHandler()->set_fail_send(true); |
(...skipping 485 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
867 | 879 |
868 LoginClient(std::vector<std::string>()); | 880 LoginClient(std::vector<std::string>()); |
869 GetFakeHandler()->ExpectOutgoingMessage(message); | 881 GetFakeHandler()->ExpectOutgoingMessage(message); |
870 GetFakeHandler()->ExpectOutgoingMessage(message2); | 882 GetFakeHandler()->ExpectOutgoingMessage(message2); |
871 PumpLoop(); | 883 PumpLoop(); |
872 } | 884 } |
873 | 885 |
874 } // namespace | 886 } // namespace |
875 | 887 |
876 } // namespace gcm | 888 } // namespace gcm |
OLD | NEW |