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 <stdint.h> | 5 #include <stdint.h> |
6 | 6 |
7 #include "base/macros.h" | 7 #include "base/macros.h" |
8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
9 #include "base/test/simple_test_tick_clock.h" | 9 #include "base/test/simple_test_tick_clock.h" |
10 #include "media/cast/cast_environment.h" | 10 #include "media/cast/cast_environment.h" |
11 #include "media/cast/net/cast_transport_defines.h" | 11 #include "media/cast/net/cast_transport_defines.h" |
12 #include "media/cast/net/rtcp/rtcp_utility.h" | 12 #include "media/cast/net/rtcp/rtcp_utility.h" |
13 #include "media/cast/net/rtcp/test_rtcp_packet_builder.h" | 13 #include "media/cast/net/rtcp/test_rtcp_packet_builder.h" |
14 #include "media/cast/test/fake_single_thread_task_runner.h" | 14 #include "media/cast/test/fake_single_thread_task_runner.h" |
15 #include "testing/gtest/include/gtest/gtest.h" | 15 #include "testing/gtest/include/gtest/gtest.h" |
16 | 16 |
17 namespace media { | 17 namespace media { |
18 namespace cast { | 18 namespace cast { |
19 | 19 |
20 static const uint32_t kSenderSsrc = 0x10203; | 20 static const uint32_t kSenderSsrc = 0x10203; |
21 static const uint32_t kSourceSsrc = 0x40506; | 21 static const uint32_t kSourceSsrc = 0x40506; |
22 static const uint32_t kUnknownSsrc = 0xDEAD; | 22 static const uint32_t kUnknownSsrc = 0xDEAD; |
23 static const base::TimeDelta kTargetDelay = | 23 static const base::TimeDelta kTargetDelay = |
24 base::TimeDelta::FromMilliseconds(100); | 24 base::TimeDelta::FromMilliseconds(100); |
25 | 25 |
26 class RtcpParserTest : public ::testing::Test { | 26 class RtcpParserTest : public ::testing::Test { |
27 protected: | 27 protected: |
28 RtcpParserTest() | 28 RtcpParserTest() |
29 : testing_clock_(new base::SimpleTestTickClock()), | 29 : testing_clock_(new base::SimpleTestTickClock(base::TimeTicks())), |
30 task_runner_(new test::FakeSingleThreadTaskRunner( | 30 task_runner_( |
31 testing_clock_.get())) { | 31 new test::FakeSingleThreadTaskRunner(testing_clock_.get())) {} |
32 } | |
33 | 32 |
34 bool HasAnything(const RtcpParser& parser) { | 33 bool HasAnything(const RtcpParser& parser) { |
35 return parser.has_sender_report() || | 34 return parser.has_sender_report() || |
36 parser.has_last_report() || | 35 parser.has_last_report() || |
37 parser.has_receiver_log() || | 36 parser.has_receiver_log() || |
38 parser.has_cast_message() || | 37 parser.has_cast_message() || |
39 parser.has_receiver_reference_time_report(); | 38 parser.has_receiver_reference_time_report(); |
40 } | 39 } |
41 | 40 |
42 void ExpectSenderInfo(const RtcpParser& parser) { | 41 void ExpectSenderInfo(const RtcpParser& parser) { |
(...skipping 278 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
321 RtcpParser parser2(kSourceSsrc, kSenderSsrc); | 320 RtcpParser parser2(kSourceSsrc, kSenderSsrc); |
322 EXPECT_TRUE(parser2.Parse(p2.Reader())); | 321 EXPECT_TRUE(parser2.Parse(p2.Reader())); |
323 ExpectLastReport(parser2); | 322 ExpectLastReport(parser2); |
324 ExpectCastFeedback(parser2); | 323 ExpectCastFeedback(parser2); |
325 } | 324 } |
326 | 325 |
327 TEST_F(RtcpParserTest, InjectReceiverReportWithReceiverLogVerificationBase) { | 326 TEST_F(RtcpParserTest, InjectReceiverReportWithReceiverLogVerificationBase) { |
328 static const uint32_t kTimeBaseMs = 12345678; | 327 static const uint32_t kTimeBaseMs = 12345678; |
329 static const uint32_t kTimeDelayMs = 10; | 328 static const uint32_t kTimeDelayMs = 10; |
330 static const uint32_t kDelayDeltaMs = 123; | 329 static const uint32_t kDelayDeltaMs = 123; |
331 base::SimpleTestTickClock testing_clock; | 330 base::SimpleTestTickClock testing_clock( |
332 testing_clock.Advance(base::TimeDelta::FromMilliseconds(kTimeBaseMs)); | 331 base::TimeTicks() + base::TimeDelta::FromMilliseconds(kTimeBaseMs)); |
333 | 332 |
334 RtcpReceiverLogMessage receiver_log; | 333 RtcpReceiverLogMessage receiver_log; |
335 RtcpReceiverFrameLogMessage frame_log(kRtpTimestamp); | 334 RtcpReceiverFrameLogMessage frame_log(kRtpTimestamp); |
336 RtcpReceiverEventLogMessage event_log; | 335 RtcpReceiverEventLogMessage event_log; |
337 | 336 |
338 event_log.type = FRAME_ACK_SENT; | 337 event_log.type = FRAME_ACK_SENT; |
339 event_log.event_timestamp = testing_clock.NowTicks(); | 338 event_log.event_timestamp = testing_clock.NowTicks(); |
340 event_log.delay_delta = base::TimeDelta::FromMilliseconds(kDelayDeltaMs); | 339 event_log.delay_delta = base::TimeDelta::FromMilliseconds(kDelayDeltaMs); |
341 frame_log.event_log_messages_.push_back(event_log); | 340 frame_log.event_log_messages_.push_back(event_log); |
342 | 341 |
(...skipping 21 matching lines...) Expand all Loading... |
364 | 363 |
365 RtcpParser parser(kSourceSsrc, kSenderSsrc); | 364 RtcpParser parser(kSourceSsrc, kSenderSsrc); |
366 EXPECT_TRUE(parser.Parse(p.Reader())); | 365 EXPECT_TRUE(parser.Parse(p.Reader())); |
367 ExpectReceiverLog(parser, receiver_log); | 366 ExpectReceiverLog(parser, receiver_log); |
368 } | 367 } |
369 | 368 |
370 TEST_F(RtcpParserTest, InjectReceiverReportWithReceiverLogVerificationMulti) { | 369 TEST_F(RtcpParserTest, InjectReceiverReportWithReceiverLogVerificationMulti) { |
371 static const uint32_t kTimeBaseMs = 12345678; | 370 static const uint32_t kTimeBaseMs = 12345678; |
372 static const uint32_t kTimeDelayMs = 10; | 371 static const uint32_t kTimeDelayMs = 10; |
373 static const int kDelayDeltaMs = 123; // To be varied for every frame. | 372 static const int kDelayDeltaMs = 123; // To be varied for every frame. |
374 base::SimpleTestTickClock testing_clock; | 373 base::SimpleTestTickClock testing_clock( |
375 testing_clock.Advance(base::TimeDelta::FromMilliseconds(kTimeBaseMs)); | 374 base::TimeTicks() + base::TimeDelta::FromMilliseconds(kTimeBaseMs)); |
376 | 375 |
377 RtcpReceiverLogMessage receiver_log; | 376 RtcpReceiverLogMessage receiver_log; |
378 | 377 |
379 for (int j = 0; j < 100; ++j) { | 378 for (int j = 0; j < 100; ++j) { |
380 RtcpReceiverFrameLogMessage frame_log(kRtpTimestamp); | 379 RtcpReceiverFrameLogMessage frame_log(kRtpTimestamp); |
381 RtcpReceiverEventLogMessage event_log; | 380 RtcpReceiverEventLogMessage event_log; |
382 event_log.type = FRAME_ACK_SENT; | 381 event_log.type = FRAME_ACK_SENT; |
383 event_log.event_timestamp = testing_clock.NowTicks(); | 382 event_log.event_timestamp = testing_clock.NowTicks(); |
384 event_log.delay_delta = | 383 event_log.delay_delta = |
385 base::TimeDelta::FromMilliseconds((j - 50) * kDelayDeltaMs); | 384 base::TimeDelta::FromMilliseconds((j - 50) * kDelayDeltaMs); |
(...skipping 12 matching lines...) Expand all Loading... |
398 p.AddReceiverEventLog(static_cast<uint16_t>(delay), FRAME_ACK_SENT, 0); | 397 p.AddReceiverEventLog(static_cast<uint16_t>(delay), FRAME_ACK_SENT, 0); |
399 } | 398 } |
400 | 399 |
401 RtcpParser parser(kSourceSsrc, kSenderSsrc); | 400 RtcpParser parser(kSourceSsrc, kSenderSsrc); |
402 EXPECT_TRUE(parser.Parse(p.Reader())); | 401 EXPECT_TRUE(parser.Parse(p.Reader())); |
403 ExpectReceiverLog(parser, receiver_log); | 402 ExpectReceiverLog(parser, receiver_log); |
404 } | 403 } |
405 | 404 |
406 } // namespace cast | 405 } // namespace cast |
407 } // namespace media | 406 } // namespace media |
OLD | NEW |