| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "net/quic/quic_chromium_alarm_factory.h" | 5 #include "net/quic/quic_chromium_alarm_factory.h" |
| 6 | 6 |
| 7 #include "net/quic/test_tools/mock_clock.h" | 7 #include "net/quic/test_tools/mock_clock.h" |
| 8 #include "net/quic/test_tools/test_task_runner.h" | 8 #include "net/quic/test_tools/test_task_runner.h" |
| 9 #include "testing/gtest/include/gtest/gtest.h" | 9 #include "testing/gtest/include/gtest/gtest.h" |
| 10 | 10 |
| (...skipping 23 matching lines...) Expand all Loading... |
| 34 scoped_refptr<TestTaskRunner> runner_; | 34 scoped_refptr<TestTaskRunner> runner_; |
| 35 QuicChromiumAlarmFactory alarm_factory_; | 35 QuicChromiumAlarmFactory alarm_factory_; |
| 36 MockClock clock_; | 36 MockClock clock_; |
| 37 }; | 37 }; |
| 38 | 38 |
| 39 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarm) { | 39 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarm) { |
| 40 TestDelegate* delegate = new TestDelegate(); | 40 TestDelegate* delegate = new TestDelegate(); |
| 41 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); | 41 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); |
| 42 | 42 |
| 43 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(1); | 43 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(1); |
| 44 alarm->Set(clock_.Now().Add(delta)); | 44 alarm->Set(clock_.Now() + delta); |
| 45 | 45 |
| 46 // Verify that the alarm task has been posted. | 46 // Verify that the alarm task has been posted. |
| 47 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); | 47 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); |
| 48 EXPECT_EQ(base::TimeDelta::FromMicroseconds(delta.ToMicroseconds()), | 48 EXPECT_EQ(base::TimeDelta::FromMicroseconds(delta.ToMicroseconds()), |
| 49 runner_->GetPostedTasks()[0].delay); | 49 runner_->GetPostedTasks()[0].delay); |
| 50 | 50 |
| 51 runner_->RunNextTask(); | 51 runner_->RunNextTask(); |
| 52 EXPECT_EQ(QuicTime::Zero().Add(delta), clock_.Now()); | 52 EXPECT_EQ(QuicTime::Zero() + delta, clock_.Now()); |
| 53 EXPECT_TRUE(delegate->fired()); | 53 EXPECT_TRUE(delegate->fired()); |
| 54 } | 54 } |
| 55 | 55 |
| 56 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarmAndCancel) { | 56 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarmAndCancel) { |
| 57 TestDelegate* delegate = new TestDelegate(); | 57 TestDelegate* delegate = new TestDelegate(); |
| 58 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); | 58 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); |
| 59 | 59 |
| 60 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(1); | 60 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(1); |
| 61 alarm->Set(clock_.Now().Add(delta)); | 61 alarm->Set(clock_.Now() + delta); |
| 62 alarm->Cancel(); | 62 alarm->Cancel(); |
| 63 | 63 |
| 64 // The alarm task should still be posted. | 64 // The alarm task should still be posted. |
| 65 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); | 65 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); |
| 66 EXPECT_EQ(base::TimeDelta::FromMicroseconds(delta.ToMicroseconds()), | 66 EXPECT_EQ(base::TimeDelta::FromMicroseconds(delta.ToMicroseconds()), |
| 67 runner_->GetPostedTasks()[0].delay); | 67 runner_->GetPostedTasks()[0].delay); |
| 68 | 68 |
| 69 runner_->RunNextTask(); | 69 runner_->RunNextTask(); |
| 70 EXPECT_EQ(QuicTime::Zero().Add(delta), clock_.Now()); | 70 EXPECT_EQ(QuicTime::Zero() + delta, clock_.Now()); |
| 71 EXPECT_FALSE(delegate->fired()); | 71 EXPECT_FALSE(delegate->fired()); |
| 72 } | 72 } |
| 73 | 73 |
| 74 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarmAndReset) { | 74 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarmAndReset) { |
| 75 TestDelegate* delegate = new TestDelegate(); | 75 TestDelegate* delegate = new TestDelegate(); |
| 76 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); | 76 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); |
| 77 | 77 |
| 78 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(1); | 78 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(1); |
| 79 alarm->Set(clock_.Now().Add(delta)); | 79 alarm->Set(clock_.Now() + delta); |
| 80 alarm->Cancel(); | 80 alarm->Cancel(); |
| 81 QuicTime::Delta new_delta = QuicTime::Delta::FromMicroseconds(3); | 81 QuicTime::Delta new_delta = QuicTime::Delta::FromMicroseconds(3); |
| 82 alarm->Set(clock_.Now().Add(new_delta)); | 82 alarm->Set(clock_.Now() + new_delta); |
| 83 | 83 |
| 84 // The alarm task should still be posted. | 84 // The alarm task should still be posted. |
| 85 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); | 85 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); |
| 86 EXPECT_EQ(base::TimeDelta::FromMicroseconds(delta.ToMicroseconds()), | 86 EXPECT_EQ(base::TimeDelta::FromMicroseconds(delta.ToMicroseconds()), |
| 87 runner_->GetPostedTasks()[0].delay); | 87 runner_->GetPostedTasks()[0].delay); |
| 88 | 88 |
| 89 runner_->RunNextTask(); | 89 runner_->RunNextTask(); |
| 90 EXPECT_EQ(QuicTime::Zero().Add(delta), clock_.Now()); | 90 EXPECT_EQ(QuicTime::Zero() + delta, clock_.Now()); |
| 91 EXPECT_FALSE(delegate->fired()); | 91 EXPECT_FALSE(delegate->fired()); |
| 92 | 92 |
| 93 // The alarm task should be posted again. | 93 // The alarm task should be posted again. |
| 94 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); | 94 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); |
| 95 | 95 |
| 96 runner_->RunNextTask(); | 96 runner_->RunNextTask(); |
| 97 EXPECT_EQ(QuicTime::Zero().Add(new_delta), clock_.Now()); | 97 EXPECT_EQ(QuicTime::Zero() + new_delta, clock_.Now()); |
| 98 EXPECT_TRUE(delegate->fired()); | 98 EXPECT_TRUE(delegate->fired()); |
| 99 } | 99 } |
| 100 | 100 |
| 101 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarmAndResetEarlier) { | 101 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarmAndResetEarlier) { |
| 102 TestDelegate* delegate = new TestDelegate(); | 102 TestDelegate* delegate = new TestDelegate(); |
| 103 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); | 103 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); |
| 104 | 104 |
| 105 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(3); | 105 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(3); |
| 106 alarm->Set(clock_.Now().Add(delta)); | 106 alarm->Set(clock_.Now() + delta); |
| 107 alarm->Cancel(); | 107 alarm->Cancel(); |
| 108 QuicTime::Delta new_delta = QuicTime::Delta::FromMicroseconds(1); | 108 QuicTime::Delta new_delta = QuicTime::Delta::FromMicroseconds(1); |
| 109 alarm->Set(clock_.Now().Add(new_delta)); | 109 alarm->Set(clock_.Now() + new_delta); |
| 110 | 110 |
| 111 // Both alarm tasks will be posted. | 111 // Both alarm tasks will be posted. |
| 112 ASSERT_EQ(2u, runner_->GetPostedTasks().size()); | 112 ASSERT_EQ(2u, runner_->GetPostedTasks().size()); |
| 113 | 113 |
| 114 // The earlier task will execute and will fire the alarm-> | 114 // The earlier task will execute and will fire the alarm-> |
| 115 runner_->RunNextTask(); | 115 runner_->RunNextTask(); |
| 116 EXPECT_EQ(QuicTime::Zero().Add(new_delta), clock_.Now()); | 116 EXPECT_EQ(QuicTime::Zero() + new_delta, clock_.Now()); |
| 117 EXPECT_TRUE(delegate->fired()); | 117 EXPECT_TRUE(delegate->fired()); |
| 118 delegate->Clear(); | 118 delegate->Clear(); |
| 119 | 119 |
| 120 // The latter task is still posted. | 120 // The latter task is still posted. |
| 121 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); | 121 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); |
| 122 | 122 |
| 123 // When the latter task is executed, the weak ptr will be invalid and | 123 // When the latter task is executed, the weak ptr will be invalid and |
| 124 // the alarm will not fire. | 124 // the alarm will not fire. |
| 125 runner_->RunNextTask(); | 125 runner_->RunNextTask(); |
| 126 EXPECT_EQ(QuicTime::Zero().Add(delta), clock_.Now()); | 126 EXPECT_EQ(QuicTime::Zero() + delta, clock_.Now()); |
| 127 EXPECT_FALSE(delegate->fired()); | 127 EXPECT_FALSE(delegate->fired()); |
| 128 } | 128 } |
| 129 | 129 |
| 130 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarmAndUpdate) { | 130 TEST_F(QuicChromiumAlarmFactoryTest, CreateAlarmAndUpdate) { |
| 131 TestDelegate* delegate = new TestDelegate(); | 131 TestDelegate* delegate = new TestDelegate(); |
| 132 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); | 132 std::unique_ptr<QuicAlarm> alarm(alarm_factory_.CreateAlarm(delegate)); |
| 133 | 133 |
| 134 QuicTime start = clock_.Now(); | 134 QuicTime start = clock_.Now(); |
| 135 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(1); | 135 QuicTime::Delta delta = QuicTime::Delta::FromMicroseconds(1); |
| 136 alarm->Set(clock_.Now().Add(delta)); | 136 alarm->Set(clock_.Now() + delta); |
| 137 QuicTime::Delta new_delta = QuicTime::Delta::FromMicroseconds(3); | 137 QuicTime::Delta new_delta = QuicTime::Delta::FromMicroseconds(3); |
| 138 alarm->Update(clock_.Now().Add(new_delta), | 138 alarm->Update(clock_.Now() + new_delta, QuicTime::Delta::FromMicroseconds(1)); |
| 139 QuicTime::Delta::FromMicroseconds(1)); | |
| 140 | 139 |
| 141 // The alarm task should still be posted. | 140 // The alarm task should still be posted. |
| 142 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); | 141 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); |
| 143 EXPECT_EQ(base::TimeDelta::FromMicroseconds(delta.ToMicroseconds()), | 142 EXPECT_EQ(base::TimeDelta::FromMicroseconds(delta.ToMicroseconds()), |
| 144 runner_->GetPostedTasks()[0].delay); | 143 runner_->GetPostedTasks()[0].delay); |
| 145 | 144 |
| 146 runner_->RunNextTask(); | 145 runner_->RunNextTask(); |
| 147 EXPECT_EQ(QuicTime::Zero().Add(delta), clock_.Now()); | 146 EXPECT_EQ(QuicTime::Zero() + delta, clock_.Now()); |
| 148 EXPECT_FALSE(delegate->fired()); | 147 EXPECT_FALSE(delegate->fired()); |
| 149 | 148 |
| 150 // Move the alarm forward 1us and ensure it doesn't move forward. | 149 // Move the alarm forward 1us and ensure it doesn't move forward. |
| 151 alarm->Update(clock_.Now().Add(new_delta), | 150 alarm->Update(clock_.Now() + new_delta, QuicTime::Delta::FromMicroseconds(2)); |
| 152 QuicTime::Delta::FromMicroseconds(2)); | |
| 153 | 151 |
| 154 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); | 152 ASSERT_EQ(1u, runner_->GetPostedTasks().size()); |
| 155 EXPECT_EQ(base::TimeDelta::FromMicroseconds( | 153 EXPECT_EQ( |
| 156 new_delta.Subtract(delta).ToMicroseconds()), | 154 base::TimeDelta::FromMicroseconds((new_delta - delta).ToMicroseconds()), |
| 157 runner_->GetPostedTasks()[0].delay); | 155 runner_->GetPostedTasks()[0].delay); |
| 158 runner_->RunNextTask(); | 156 runner_->RunNextTask(); |
| 159 EXPECT_EQ(start.Add(new_delta), clock_.Now()); | 157 EXPECT_EQ(start + new_delta, clock_.Now()); |
| 160 EXPECT_TRUE(delegate->fired()); | 158 EXPECT_TRUE(delegate->fired()); |
| 161 | 159 |
| 162 // Set the alarm via an update call. | 160 // Set the alarm via an update call. |
| 163 new_delta = QuicTime::Delta::FromMicroseconds(5); | 161 new_delta = QuicTime::Delta::FromMicroseconds(5); |
| 164 alarm->Update(clock_.Now().Add(new_delta), | 162 alarm->Update(clock_.Now() + new_delta, QuicTime::Delta::FromMicroseconds(1)); |
| 165 QuicTime::Delta::FromMicroseconds(1)); | |
| 166 EXPECT_TRUE(alarm->IsSet()); | 163 EXPECT_TRUE(alarm->IsSet()); |
| 167 | 164 |
| 168 // Update it with an uninitialized time and ensure it's cancelled. | 165 // Update it with an uninitialized time and ensure it's cancelled. |
| 169 alarm->Update(QuicTime::Zero(), QuicTime::Delta::FromMicroseconds(1)); | 166 alarm->Update(QuicTime::Zero(), QuicTime::Delta::FromMicroseconds(1)); |
| 170 EXPECT_FALSE(alarm->IsSet()); | 167 EXPECT_FALSE(alarm->IsSet()); |
| 171 } | 168 } |
| 172 | 169 |
| 173 } // namespace | 170 } // namespace |
| 174 } // namespace test | 171 } // namespace test |
| 175 } // namespace net | 172 } // namespace net |
| OLD | NEW |