| 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 "base/memory/ref_counted.h" | 5 #include "base/memory/ref_counted.h" |
| 6 #include "base/memory/scoped_ptr.h" | 6 #include "base/memory/scoped_ptr.h" |
| 7 #include "base/test/simple_test_tick_clock.h" | 7 #include "base/test/simple_test_tick_clock.h" |
| 8 #include "base/time/tick_clock.h" | 8 #include "base/time/tick_clock.h" |
| 9 #include "media/cast/cast_environment.h" | 9 #include "media/cast/cast_environment.h" |
| 10 #include "media/cast/logging/logging_defines.h" | 10 #include "media/cast/logging/logging_defines.h" |
| 11 #include "media/cast/logging/receiver_time_offset_estimator_impl.h" | 11 #include "media/cast/logging/receiver_time_offset_estimator_impl.h" |
| 12 #include "media/cast/test/fake_single_thread_task_runner.h" | 12 #include "media/cast/test/fake_single_thread_task_runner.h" |
| 13 #include "testing/gtest/include/gtest/gtest.h" | 13 #include "testing/gtest/include/gtest/gtest.h" |
| 14 | 14 |
| 15 namespace media { | 15 namespace media { |
| 16 namespace cast { | 16 namespace cast { |
| 17 | 17 |
| 18 class ReceiverTimeOffsetEstimatorImplTest : public ::testing::Test { | 18 class ReceiverTimeOffsetEstimatorImplTest : public ::testing::Test { |
| 19 protected: | 19 protected: |
| 20 ReceiverTimeOffsetEstimatorImplTest() | 20 ReceiverTimeOffsetEstimatorImplTest() |
| 21 : sender_clock_(new base::SimpleTestTickClock()), | 21 : sender_clock_(new base::SimpleTestTickClock()), |
| 22 task_runner_(new test::FakeSingleThreadTaskRunner(sender_clock_)), | 22 task_runner_(new test::FakeSingleThreadTaskRunner(sender_clock_)), |
| 23 cast_environment_(new CastEnvironment( | 23 cast_environment_(new CastEnvironment( |
| 24 scoped_ptr<base::TickClock>(sender_clock_).Pass(), | 24 scoped_ptr<base::TickClock>(sender_clock_).Pass(), |
| 25 task_runner_, | 25 task_runner_, |
| 26 task_runner_, | 26 task_runner_, |
| 27 task_runner_)), | 27 task_runner_)) { |
| 28 estimator_(cast_environment_->Clock()) { | |
| 29 cast_environment_->Logging()->AddRawEventSubscriber(&estimator_); | 28 cast_environment_->Logging()->AddRawEventSubscriber(&estimator_); |
| 30 } | 29 } |
| 31 | 30 |
| 32 virtual ~ReceiverTimeOffsetEstimatorImplTest() { | 31 virtual ~ReceiverTimeOffsetEstimatorImplTest() { |
| 33 cast_environment_->Logging()->RemoveRawEventSubscriber(&estimator_); | 32 cast_environment_->Logging()->RemoveRawEventSubscriber(&estimator_); |
| 34 } | 33 } |
| 35 | 34 |
| 36 void AdvanceClocks(base::TimeDelta time) { | 35 void AdvanceClocks(base::TimeDelta time) { |
| 37 sender_clock_->Advance(time); | 36 sender_clock_->Advance(time); |
| 38 receiver_clock_.Advance(time); | 37 receiver_clock_.Advance(time); |
| (...skipping 27 matching lines...) Expand all Loading... |
| 66 | 65 |
| 67 cast_environment_->Logging()->InsertEncodedFrameEvent( | 66 cast_environment_->Logging()->InsertEncodedFrameEvent( |
| 68 sender_clock_->NowTicks(), | 67 sender_clock_->NowTicks(), |
| 69 FRAME_ENCODED, VIDEO_EVENT, | 68 FRAME_ENCODED, VIDEO_EVENT, |
| 70 rtp_timestamp, | 69 rtp_timestamp, |
| 71 frame_id, | 70 frame_id, |
| 72 1234, | 71 1234, |
| 73 true, | 72 true, |
| 74 5678); | 73 5678); |
| 75 | 74 |
| 75 cast_environment_->Logging()->InsertPacketEvent( |
| 76 sender_clock_->NowTicks(), |
| 77 PACKET_SENT_TO_NETWORK, VIDEO_EVENT, |
| 78 rtp_timestamp, |
| 79 frame_id, |
| 80 56, 78, 1500); |
| 81 |
| 76 EXPECT_FALSE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); | 82 EXPECT_FALSE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); |
| 77 | 83 |
| 78 AdvanceClocks(base::TimeDelta::FromMilliseconds(10)); | 84 AdvanceClocks(base::TimeDelta::FromMilliseconds(10)); |
| 79 cast_environment_->Logging()->InsertFrameEvent( | 85 cast_environment_->Logging()->InsertFrameEvent( |
| 80 receiver_clock_.NowTicks(), FRAME_ACK_SENT, VIDEO_EVENT, | 86 receiver_clock_.NowTicks(), FRAME_ACK_SENT, VIDEO_EVENT, |
| 81 rtp_timestamp, frame_id); | 87 rtp_timestamp, frame_id); |
| 82 | 88 |
| 89 cast_environment_->Logging()->InsertPacketEvent( |
| 90 receiver_clock_.NowTicks(), |
| 91 PACKET_RECEIVED, VIDEO_EVENT, |
| 92 rtp_timestamp, |
| 93 frame_id, |
| 94 56, 78, 1500); |
| 95 |
| 83 EXPECT_FALSE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); | 96 EXPECT_FALSE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); |
| 84 | 97 |
| 85 AdvanceClocks(base::TimeDelta::FromMilliseconds(30)); | 98 AdvanceClocks(base::TimeDelta::FromMilliseconds(30)); |
| 86 cast_environment_->Logging()->InsertFrameEvent( | 99 cast_environment_->Logging()->InsertFrameEvent( |
| 87 sender_clock_->NowTicks(), FRAME_ACK_RECEIVED, VIDEO_EVENT, | 100 sender_clock_->NowTicks(), FRAME_ACK_RECEIVED, VIDEO_EVENT, |
| 88 rtp_timestamp, frame_id); | 101 rtp_timestamp, frame_id); |
| 89 | 102 |
| 90 EXPECT_TRUE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); | 103 EXPECT_TRUE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); |
| 91 | 104 |
| 92 int64 lower_bound_ms = lower_bound.InMilliseconds(); | 105 int64 lower_bound_ms = lower_bound.InMilliseconds(); |
| (...skipping 22 matching lines...) Expand all Loading... |
| 115 | 128 |
| 116 cast_environment_->Logging()->InsertEncodedFrameEvent( | 129 cast_environment_->Logging()->InsertEncodedFrameEvent( |
| 117 sender_clock_->NowTicks(), | 130 sender_clock_->NowTicks(), |
| 118 FRAME_ENCODED, VIDEO_EVENT, | 131 FRAME_ENCODED, VIDEO_EVENT, |
| 119 rtp_timestamp, | 132 rtp_timestamp, |
| 120 frame_id, | 133 frame_id, |
| 121 1234, | 134 1234, |
| 122 true, | 135 true, |
| 123 5678); | 136 5678); |
| 124 | 137 |
| 138 cast_environment_->Logging()->InsertPacketEvent( |
| 139 sender_clock_->NowTicks(), |
| 140 PACKET_SENT_TO_NETWORK, VIDEO_EVENT, |
| 141 rtp_timestamp, |
| 142 frame_id, |
| 143 56, 78, 1500); |
| 144 |
| 125 EXPECT_FALSE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); | 145 EXPECT_FALSE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); |
| 126 | 146 |
| 127 AdvanceClocks(base::TimeDelta::FromMilliseconds(10)); | 147 AdvanceClocks(base::TimeDelta::FromMilliseconds(10)); |
| 128 base::TimeTicks event_b_time = receiver_clock_.NowTicks(); | 148 base::TimeTicks event_b_time = receiver_clock_.NowTicks(); |
| 129 AdvanceClocks(base::TimeDelta::FromMilliseconds(30)); | 149 AdvanceClocks(base::TimeDelta::FromMilliseconds(30)); |
| 130 base::TimeTicks event_c_time = sender_clock_->NowTicks(); | 150 base::TimeTicks event_c_time = sender_clock_->NowTicks(); |
| 131 | 151 |
| 132 cast_environment_->Logging()->InsertFrameEvent( | 152 cast_environment_->Logging()->InsertFrameEvent( |
| 133 event_c_time, FRAME_ACK_RECEIVED, VIDEO_EVENT, rtp_timestamp, frame_id); | 153 event_c_time, FRAME_ACK_RECEIVED, VIDEO_EVENT, rtp_timestamp, frame_id); |
| 134 | 154 |
| 135 EXPECT_FALSE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); | 155 EXPECT_FALSE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); |
| 136 | 156 |
| 157 cast_environment_->Logging()->InsertPacketEvent( |
| 158 event_b_time, |
| 159 PACKET_RECEIVED, VIDEO_EVENT, |
| 160 rtp_timestamp, |
| 161 frame_id, |
| 162 56, 78, 1500); |
| 163 |
| 137 cast_environment_->Logging()->InsertFrameEvent( | 164 cast_environment_->Logging()->InsertFrameEvent( |
| 138 event_b_time, FRAME_ACK_SENT, VIDEO_EVENT, rtp_timestamp, frame_id); | 165 event_b_time, FRAME_ACK_SENT, VIDEO_EVENT, rtp_timestamp, frame_id); |
| 139 | 166 |
| 140 EXPECT_TRUE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); | 167 EXPECT_TRUE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); |
| 141 | 168 |
| 142 int64 lower_bound_ms = lower_bound.InMilliseconds(); | 169 int64 lower_bound_ms = lower_bound.InMilliseconds(); |
| 143 int64 upper_bound_ms = upper_bound.InMilliseconds(); | 170 int64 upper_bound_ms = upper_bound.InMilliseconds(); |
| 144 EXPECT_EQ(70, lower_bound_ms); | 171 EXPECT_EQ(70, lower_bound_ms); |
| 145 EXPECT_EQ(110, upper_bound_ms); | 172 EXPECT_EQ(110, upper_bound_ms); |
| 146 EXPECT_GE(true_offset_ms, lower_bound_ms); | 173 EXPECT_GE(true_offset_ms, lower_bound_ms); |
| (...skipping 22 matching lines...) Expand all Loading... |
| 169 AdvanceClocks(base::TimeDelta::FromMilliseconds(20)); | 196 AdvanceClocks(base::TimeDelta::FromMilliseconds(20)); |
| 170 cast_environment_->Logging()->InsertEncodedFrameEvent( | 197 cast_environment_->Logging()->InsertEncodedFrameEvent( |
| 171 sender_clock_->NowTicks(), | 198 sender_clock_->NowTicks(), |
| 172 FRAME_ENCODED, VIDEO_EVENT, | 199 FRAME_ENCODED, VIDEO_EVENT, |
| 173 rtp_timestamp_a, | 200 rtp_timestamp_a, |
| 174 frame_id_a, | 201 frame_id_a, |
| 175 1234, | 202 1234, |
| 176 true, | 203 true, |
| 177 5678); | 204 5678); |
| 178 | 205 |
| 206 cast_environment_->Logging()->InsertPacketEvent( |
| 207 sender_clock_->NowTicks(), |
| 208 PACKET_SENT_TO_NETWORK, VIDEO_EVENT, |
| 209 rtp_timestamp_a, |
| 210 frame_id_a, |
| 211 56, 78, 1500); |
| 212 |
| 179 AdvanceClocks(base::TimeDelta::FromMilliseconds(10)); | 213 AdvanceClocks(base::TimeDelta::FromMilliseconds(10)); |
| 180 cast_environment_->Logging()->InsertEncodedFrameEvent( | 214 cast_environment_->Logging()->InsertEncodedFrameEvent( |
| 181 sender_clock_->NowTicks(), | 215 sender_clock_->NowTicks(), |
| 182 FRAME_ENCODED, VIDEO_EVENT, | 216 FRAME_ENCODED, VIDEO_EVENT, |
| 183 rtp_timestamp_b, | 217 rtp_timestamp_b, |
| 184 frame_id_b, | 218 frame_id_b, |
| 185 1234, | 219 1234, |
| 186 true, | 220 true, |
| 187 5678); | 221 5678); |
| 222 |
| 223 cast_environment_->Logging()->InsertPacketEvent( |
| 224 sender_clock_->NowTicks(), |
| 225 PACKET_SENT_TO_NETWORK, VIDEO_EVENT, |
| 226 rtp_timestamp_b, |
| 227 frame_id_b, |
| 228 56, 78, 1500); |
| 229 |
| 188 cast_environment_->Logging()->InsertFrameEvent( | 230 cast_environment_->Logging()->InsertFrameEvent( |
| 189 receiver_clock_.NowTicks(), FRAME_ACK_SENT, VIDEO_EVENT, | 231 receiver_clock_.NowTicks(), FRAME_ACK_SENT, VIDEO_EVENT, |
| 190 rtp_timestamp_a, frame_id_a); | 232 rtp_timestamp_a, frame_id_a); |
| 191 | 233 |
| 192 AdvanceClocks(base::TimeDelta::FromMilliseconds(20)); | 234 AdvanceClocks(base::TimeDelta::FromMilliseconds(20)); |
| 235 |
| 236 cast_environment_->Logging()->InsertPacketEvent( |
| 237 receiver_clock_.NowTicks(), |
| 238 PACKET_RECEIVED, VIDEO_EVENT, |
| 239 rtp_timestamp_b, |
| 240 frame_id_b, |
| 241 56, 78, 1500); |
| 242 |
| 193 cast_environment_->Logging()->InsertFrameEvent( | 243 cast_environment_->Logging()->InsertFrameEvent( |
| 194 receiver_clock_.NowTicks(), FRAME_ACK_SENT, VIDEO_EVENT, | 244 receiver_clock_.NowTicks(), FRAME_ACK_SENT, VIDEO_EVENT, |
| 195 rtp_timestamp_b, frame_id_b); | 245 rtp_timestamp_b, frame_id_b); |
| 196 | 246 |
| 197 AdvanceClocks(base::TimeDelta::FromMilliseconds(5)); | 247 AdvanceClocks(base::TimeDelta::FromMilliseconds(5)); |
| 198 cast_environment_->Logging()->InsertFrameEvent(sender_clock_->NowTicks(), | 248 cast_environment_->Logging()->InsertFrameEvent(sender_clock_->NowTicks(), |
| 199 FRAME_ACK_RECEIVED, | 249 FRAME_ACK_RECEIVED, |
| 200 VIDEO_EVENT, | 250 VIDEO_EVENT, |
| 201 rtp_timestamp_b, | 251 rtp_timestamp_b, |
| 202 frame_id_b); | 252 frame_id_b); |
| 203 | 253 |
| 204 AdvanceClocks(base::TimeDelta::FromMilliseconds(5)); | 254 AdvanceClocks(base::TimeDelta::FromMilliseconds(5)); |
| 205 cast_environment_->Logging()->InsertFrameEvent(sender_clock_->NowTicks(), | 255 cast_environment_->Logging()->InsertFrameEvent(sender_clock_->NowTicks(), |
| 206 FRAME_ACK_RECEIVED, | 256 FRAME_ACK_RECEIVED, |
| 207 VIDEO_EVENT, | 257 VIDEO_EVENT, |
| 208 rtp_timestamp_a, | 258 rtp_timestamp_a, |
| 209 frame_id_a); | 259 frame_id_a); |
| 210 | 260 |
| 211 AdvanceClocks(base::TimeDelta::FromMilliseconds(17)); | 261 AdvanceClocks(base::TimeDelta::FromMilliseconds(17)); |
| 212 cast_environment_->Logging()->InsertEncodedFrameEvent( | 262 cast_environment_->Logging()->InsertEncodedFrameEvent( |
| 213 sender_clock_->NowTicks(), | 263 sender_clock_->NowTicks(), |
| 214 FRAME_ENCODED, VIDEO_EVENT, | 264 FRAME_ENCODED, VIDEO_EVENT, |
| 215 rtp_timestamp_c, | 265 rtp_timestamp_c, |
| 216 frame_id_c, | 266 frame_id_c, |
| 217 1234, | 267 1234, |
| 218 true, | 268 true, |
| 219 5678); | 269 5678); |
| 220 | 270 |
| 271 cast_environment_->Logging()->InsertPacketEvent( |
| 272 sender_clock_->NowTicks(), |
| 273 PACKET_SENT_TO_NETWORK, VIDEO_EVENT, |
| 274 rtp_timestamp_c, |
| 275 frame_id_c, |
| 276 56, 78, 1500); |
| 277 |
| 221 AdvanceClocks(base::TimeDelta::FromMilliseconds(3)); | 278 AdvanceClocks(base::TimeDelta::FromMilliseconds(3)); |
| 279 cast_environment_->Logging()->InsertPacketEvent( |
| 280 receiver_clock_.NowTicks(), |
| 281 PACKET_RECEIVED, VIDEO_EVENT, |
| 282 rtp_timestamp_c, |
| 283 frame_id_c, |
| 284 56, 78, 1500); |
| 285 |
| 222 cast_environment_->Logging()->InsertFrameEvent( | 286 cast_environment_->Logging()->InsertFrameEvent( |
| 223 receiver_clock_.NowTicks(), FRAME_ACK_SENT, VIDEO_EVENT, | 287 receiver_clock_.NowTicks(), FRAME_ACK_SENT, VIDEO_EVENT, |
| 224 rtp_timestamp_c, frame_id_c); | 288 rtp_timestamp_c, frame_id_c); |
| 225 | 289 |
| 226 AdvanceClocks(base::TimeDelta::FromMilliseconds(30)); | 290 AdvanceClocks(base::TimeDelta::FromMilliseconds(30)); |
| 227 cast_environment_->Logging()->InsertFrameEvent(sender_clock_->NowTicks(), | 291 cast_environment_->Logging()->InsertFrameEvent(sender_clock_->NowTicks(), |
| 228 FRAME_ACK_RECEIVED, | 292 FRAME_ACK_RECEIVED, |
| 229 VIDEO_EVENT, | 293 VIDEO_EVENT, |
| 230 rtp_timestamp_c, | 294 rtp_timestamp_c, |
| 231 frame_id_c); | 295 frame_id_c); |
| 232 | 296 |
| 233 EXPECT_TRUE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); | 297 EXPECT_TRUE(estimator_.GetReceiverOffsetBounds(&lower_bound, &upper_bound)); |
| 234 int64 lower_bound_ms = lower_bound.InMilliseconds(); | 298 int64 lower_bound_ms = lower_bound.InMilliseconds(); |
| 235 int64 upper_bound_ms = upper_bound.InMilliseconds(); | 299 int64 upper_bound_ms = upper_bound.InMilliseconds(); |
| 236 EXPECT_EQ(95, lower_bound_ms); | 300 EXPECT_GT(lower_bound_ms, 90); |
| 237 EXPECT_EQ(103, upper_bound_ms); | 301 EXPECT_LE(lower_bound_ms, true_offset_ms); |
| 238 EXPECT_GE(true_offset_ms, lower_bound_ms); | 302 EXPECT_LT(upper_bound_ms, 150); |
| 239 EXPECT_LE(true_offset_ms, upper_bound_ms); | 303 EXPECT_GT(upper_bound_ms, true_offset_ms); |
| 240 } | 304 } |
| 241 | 305 |
| 242 } // namespace cast | 306 } // namespace cast |
| 243 } // namespace media | 307 } // namespace media |
| OLD | NEW |