| 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/rtcp/receiver_rtcp_event_subscriber.h" | 11 #include "media/cast/rtcp/receiver_rtcp_event_subscriber.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 namespace { | 18 namespace { |
| 19 | 19 |
| 20 const size_t kSizeThreshold = 10u; | 20 const size_t kMaxEventEntries = 10u; |
| 21 const int64 kDelayMs = 20L; | 21 const int64 kDelayMs = 20L; |
| 22 | 22 |
| 23 } // namespace | 23 } // namespace |
| 24 | 24 |
| 25 class ReceiverRtcpEventSubscriberTest : public ::testing::Test { | 25 class ReceiverRtcpEventSubscriberTest : public ::testing::Test { |
| 26 protected: | 26 protected: |
| 27 ReceiverRtcpEventSubscriberTest() | 27 ReceiverRtcpEventSubscriberTest() |
| 28 : testing_clock_(new base::SimpleTestTickClock()), | 28 : testing_clock_(new base::SimpleTestTickClock()), |
| 29 task_runner_(new test::FakeSingleThreadTaskRunner(testing_clock_)), | 29 task_runner_(new test::FakeSingleThreadTaskRunner(testing_clock_)), |
| 30 cast_environment_(new CastEnvironment( | 30 cast_environment_(new CastEnvironment( |
| 31 scoped_ptr<base::TickClock>(testing_clock_).Pass(), task_runner_, | 31 scoped_ptr<base::TickClock>(testing_clock_).Pass(), task_runner_, |
| 32 task_runner_, task_runner_, task_runner_, task_runner_, | 32 task_runner_, task_runner_, task_runner_, task_runner_, |
| 33 task_runner_, GetLoggingConfigWithRawEventsAndStatsEnabled())) {} | 33 task_runner_, GetLoggingConfigWithRawEventsAndStatsEnabled())) {} |
| 34 | 34 |
| 35 virtual ~ReceiverRtcpEventSubscriberTest() {} | 35 virtual ~ReceiverRtcpEventSubscriberTest() {} |
| 36 | 36 |
| 37 virtual void TearDown() OVERRIDE { | 37 virtual void TearDown() OVERRIDE { |
| 38 if (event_subscriber_) { | 38 if (event_subscriber_) { |
| 39 cast_environment_->Logging()->RemoveRawEventSubscriber( | 39 cast_environment_->Logging()->RemoveRawEventSubscriber( |
| 40 event_subscriber_.get()); | 40 event_subscriber_.get()); |
| 41 } | 41 } |
| 42 } | 42 } |
| 43 | 43 |
| 44 void Init(ReceiverRtcpEventSubscriber::Type type) { | 44 void Init(ReceiverRtcpEventSubscriber::Type type) { |
| 45 event_subscriber_.reset( | 45 event_subscriber_.reset( |
| 46 new ReceiverRtcpEventSubscriber(task_runner_, kSizeThreshold, type)); | 46 new ReceiverRtcpEventSubscriber(kMaxEventEntries, type)); |
| 47 cast_environment_->Logging()->AddRawEventSubscriber( | 47 cast_environment_->Logging()->AddRawEventSubscriber( |
| 48 event_subscriber_.get()); | 48 event_subscriber_.get()); |
| 49 } | 49 } |
| 50 | 50 |
| 51 void InsertEvents() { | 51 void InsertEvents() { |
| 52 // Video events | 52 // Video events |
| 53 cast_environment_->Logging()->InsertFrameEventWithDelay( | 53 cast_environment_->Logging()->InsertFrameEventWithDelay( |
| 54 testing_clock_->NowTicks(), kVideoRenderDelay, /*rtp_timestamp*/ 100u, | 54 testing_clock_->NowTicks(), kVideoRenderDelay, /*rtp_timestamp*/ 100u, |
| 55 /*frame_id*/ 2u, base::TimeDelta::FromMilliseconds(kDelayMs)); | 55 /*frame_id*/ 2u, base::TimeDelta::FromMilliseconds(kDelayMs)); |
| 56 cast_environment_->Logging()->InsertFrameEvent( | 56 cast_environment_->Logging()->InsertFrameEvent( |
| (...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 176 event_subscriber_->GetReceiverLogMessageAndReset(&receiver_log); | 176 event_subscriber_->GetReceiverLogMessageAndReset(&receiver_log); |
| 177 | 177 |
| 178 // Event with RTP timestamp 10 should have been dropped when 110 is inserted. | 178 // Event with RTP timestamp 10 should have been dropped when 110 is inserted. |
| 179 ASSERT_EQ(10u, receiver_log.size()); | 179 ASSERT_EQ(10u, receiver_log.size()); |
| 180 EXPECT_EQ(20u, receiver_log.begin()->rtp_timestamp_); | 180 EXPECT_EQ(20u, receiver_log.begin()->rtp_timestamp_); |
| 181 EXPECT_EQ(110u, receiver_log.rbegin()->rtp_timestamp_); | 181 EXPECT_EQ(110u, receiver_log.rbegin()->rtp_timestamp_); |
| 182 } | 182 } |
| 183 | 183 |
| 184 } // namespace cast | 184 } // namespace cast |
| 185 } // namespace media | 185 } // namespace media |
| OLD | NEW |