| 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 |