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