| 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 <vector> | 5 #include <vector> |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
| 9 #include "base/run_loop.h" | 9 #include "base/run_loop.h" |
| 10 #include "base/test/simple_test_tick_clock.h" | 10 #include "base/test/simple_test_tick_clock.h" |
| 11 #include "media/base/gmock_callback_support.h" | 11 #include "media/base/gmock_callback_support.h" |
| 12 #include "media/base/mock_filters.h" | 12 #include "media/base/mock_filters.h" |
| 13 #include "media/base/test_helpers.h" | 13 #include "media/base/test_helpers.h" |
| 14 #include "media/renderers/renderer_impl.h" | 14 #include "media/renderers/renderer_impl.h" |
| 15 #include "testing/gtest/include/gtest/gtest.h" | 15 #include "testing/gtest/include/gtest/gtest.h" |
| 16 | 16 |
| 17 using ::testing::_; | 17 using ::testing::_; |
| 18 using ::testing::DoAll; | 18 using ::testing::DoAll; |
| 19 using ::testing::InSequence; | 19 using ::testing::InSequence; |
| 20 using ::testing::Mock; | 20 using ::testing::Mock; |
| 21 using ::testing::Return; | 21 using ::testing::Return; |
| 22 using ::testing::SaveArg; | 22 using ::testing::SaveArg; |
| 23 using ::testing::StrictMock; | 23 using ::testing::StrictMock; |
| 24 | 24 |
| 25 namespace media { | 25 namespace media { |
| 26 | 26 |
| 27 const int64 kStartPlayingTimeInMs = 100; | 27 const int64_t kStartPlayingTimeInMs = 100; |
| 28 | 28 |
| 29 ACTION_P2(SetBufferingState, cb, buffering_state) { | 29 ACTION_P2(SetBufferingState, cb, buffering_state) { |
| 30 cb->Run(buffering_state); | 30 cb->Run(buffering_state); |
| 31 } | 31 } |
| 32 | 32 |
| 33 ACTION_P2(AudioError, cb, error) { | 33 ACTION_P2(AudioError, cb, error) { |
| 34 cb->Run(error); | 34 cb->Run(error); |
| 35 } | 35 } |
| 36 | 36 |
| 37 class RendererImplTest : public ::testing::Test { | 37 class RendererImplTest : public ::testing::Test { |
| (...skipping 178 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 216 base::Bind(&CallbackHelper::OnFlushed, base::Unretained(&callbacks_))); | 216 base::Bind(&CallbackHelper::OnFlushed, base::Unretained(&callbacks_))); |
| 217 base::RunLoop().RunUntilIdle(); | 217 base::RunLoop().RunUntilIdle(); |
| 218 } | 218 } |
| 219 | 219 |
| 220 void SetPlaybackRate(double playback_rate) { | 220 void SetPlaybackRate(double playback_rate) { |
| 221 EXPECT_CALL(time_source_, SetPlaybackRate(playback_rate)); | 221 EXPECT_CALL(time_source_, SetPlaybackRate(playback_rate)); |
| 222 renderer_impl_->SetPlaybackRate(playback_rate); | 222 renderer_impl_->SetPlaybackRate(playback_rate); |
| 223 base::RunLoop().RunUntilIdle(); | 223 base::RunLoop().RunUntilIdle(); |
| 224 } | 224 } |
| 225 | 225 |
| 226 int64 GetMediaTimeMs() { | 226 int64_t GetMediaTimeMs() { |
| 227 return renderer_impl_->GetMediaTime().InMilliseconds(); | 227 return renderer_impl_->GetMediaTime().InMilliseconds(); |
| 228 } | 228 } |
| 229 | 229 |
| 230 bool IsMediaTimeAdvancing(double playback_rate) { | 230 bool IsMediaTimeAdvancing(double playback_rate) { |
| 231 int64 start_time_ms = GetMediaTimeMs(); | 231 int64_t start_time_ms = GetMediaTimeMs(); |
| 232 const int64 time_to_advance_ms = 100; | 232 const int64_t time_to_advance_ms = 100; |
| 233 | 233 |
| 234 test_tick_clock_.Advance( | 234 test_tick_clock_.Advance( |
| 235 base::TimeDelta::FromMilliseconds(time_to_advance_ms)); | 235 base::TimeDelta::FromMilliseconds(time_to_advance_ms)); |
| 236 | 236 |
| 237 if (GetMediaTimeMs() == start_time_ms + time_to_advance_ms * playback_rate) | 237 if (GetMediaTimeMs() == start_time_ms + time_to_advance_ms * playback_rate) |
| 238 return true; | 238 return true; |
| 239 | 239 |
| 240 DCHECK_EQ(start_time_ms, GetMediaTimeMs()); | 240 DCHECK_EQ(start_time_ms, GetMediaTimeMs()); |
| 241 return false; | 241 return false; |
| 242 } | 242 } |
| (...skipping 353 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 596 .WillOnce( | 596 .WillOnce( |
| 597 SetBufferingState(&audio_buffering_state_cb_, BUFFERING_HAVE_ENOUGH)); | 597 SetBufferingState(&audio_buffering_state_cb_, BUFFERING_HAVE_ENOUGH)); |
| 598 EXPECT_CALL(*video_renderer_, StartPlayingFrom(kStartTime)); | 598 EXPECT_CALL(*video_renderer_, StartPlayingFrom(kStartTime)); |
| 599 renderer_impl_->StartPlayingFrom(kStartTime); | 599 renderer_impl_->StartPlayingFrom(kStartTime); |
| 600 | 600 |
| 601 // Nothing else should primed on the message loop. | 601 // Nothing else should primed on the message loop. |
| 602 base::RunLoop().RunUntilIdle(); | 602 base::RunLoop().RunUntilIdle(); |
| 603 } | 603 } |
| 604 | 604 |
| 605 } // namespace media | 605 } // namespace media |
| OLD | NEW |