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 |