| 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/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/files/file_path.h" | 10 #include "base/files/file_path.h" |
| 11 #include "base/files/memory_mapped_file.h" | 11 #include "base/files/memory_mapped_file.h" |
| 12 #include "base/logging.h" | 12 #include "base/logging.h" |
| 13 #include "base/memory/ref_counted.h" | 13 #include "base/memory/ref_counted.h" |
| 14 #include "base/memory/scoped_ptr.h" | 14 #include "base/memory/scoped_ptr.h" |
| 15 #include "base/memory/scoped_vector.h" | 15 #include "base/memory/scoped_vector.h" |
| 16 #include "base/message_loop/message_loop.h" | 16 #include "base/message_loop/message_loop.h" |
| 17 #include "base/message_loop/message_loop_proxy.h" | |
| 18 #include "base/path_service.h" | 17 #include "base/path_service.h" |
| 18 #include "base/single_thread_task_runner.h" |
| 19 #include "base/thread_task_runner_handle.h" |
| 19 #include "base/threading/thread.h" | 20 #include "base/threading/thread.h" |
| 20 #include "base/time/time.h" | 21 #include "base/time/time.h" |
| 21 #include "chromecast/media/base/decrypt_context.h" | 22 #include "chromecast/media/base/decrypt_context.h" |
| 22 #include "chromecast/media/cma/backend/audio_pipeline_device.h" | 23 #include "chromecast/media/cma/backend/audio_pipeline_device.h" |
| 23 #include "chromecast/media/cma/backend/media_clock_device.h" | 24 #include "chromecast/media/cma/backend/media_clock_device.h" |
| 24 #include "chromecast/media/cma/backend/media_pipeline_device.h" | 25 #include "chromecast/media/cma/backend/media_pipeline_device.h" |
| 25 #include "chromecast/media/cma/backend/media_pipeline_device_params.h" | 26 #include "chromecast/media/cma/backend/media_pipeline_device_params.h" |
| 26 #include "chromecast/media/cma/backend/video_pipeline_device.h" | 27 #include "chromecast/media/cma/backend/video_pipeline_device.h" |
| 27 #include "chromecast/media/cma/base/decoder_buffer_adapter.h" | 28 #include "chromecast/media/cma/base/decoder_buffer_adapter.h" |
| 28 #include "chromecast/media/cma/base/decoder_buffer_base.h" | 29 #include "chromecast/media/cma/base/decoder_buffer_base.h" |
| (...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 230 base::Unretained(this), | 231 base::Unretained(this), |
| 231 device_feeder)); | 232 device_feeder)); |
| 232 component_device_feeders_.push_back(device_feeder); | 233 component_device_feeders_.push_back(device_feeder); |
| 233 } | 234 } |
| 234 | 235 |
| 235 void AudioVideoPipelineDeviceTest::Start() { | 236 void AudioVideoPipelineDeviceTest::Start() { |
| 236 pause_time_ = base::TimeDelta(); | 237 pause_time_ = base::TimeDelta(); |
| 237 pause_pattern_idx_ = 0; | 238 pause_pattern_idx_ = 0; |
| 238 | 239 |
| 239 for (size_t i = 0; i < component_device_feeders_.size(); i++) { | 240 for (size_t i = 0; i < component_device_feeders_.size(); i++) { |
| 240 base::MessageLoopProxy::current()->PostTask( | 241 base::ThreadTaskRunnerHandle::Get()->PostTask( |
| 241 FROM_HERE, | 242 FROM_HERE, base::Bind(&MediaComponentDeviceFeederForTest::Feed, |
| 242 base::Bind(&MediaComponentDeviceFeederForTest::Feed, | 243 base::Unretained(component_device_feeders_[i]))); |
| 243 base::Unretained(component_device_feeders_[i]))); | |
| 244 } | 244 } |
| 245 | 245 |
| 246 media_clock_device_->SetState(MediaClockDevice::kStateRunning); | 246 media_clock_device_->SetState(MediaClockDevice::kStateRunning); |
| 247 | 247 |
| 248 base::MessageLoopProxy::current()->PostTask( | 248 base::ThreadTaskRunnerHandle::Get()->PostTask( |
| 249 FROM_HERE, | 249 FROM_HERE, base::Bind(&AudioVideoPipelineDeviceTest::MonitorLoop, |
| 250 base::Bind(&AudioVideoPipelineDeviceTest::MonitorLoop, | 250 base::Unretained(this))); |
| 251 base::Unretained(this))); | |
| 252 } | 251 } |
| 253 | 252 |
| 254 void AudioVideoPipelineDeviceTest::MonitorLoop() { | 253 void AudioVideoPipelineDeviceTest::MonitorLoop() { |
| 255 base::TimeDelta media_time = media_clock_device_->GetTime(); | 254 base::TimeDelta media_time = media_clock_device_->GetTime(); |
| 256 | 255 |
| 257 if (!pause_pattern_.empty() && | 256 if (!pause_pattern_.empty() && |
| 258 pause_pattern_[pause_pattern_idx_].delay >= base::TimeDelta() && | 257 pause_pattern_[pause_pattern_idx_].delay >= base::TimeDelta() && |
| 259 media_time >= pause_time_ + pause_pattern_[pause_pattern_idx_].delay) { | 258 media_time >= pause_time_ + pause_pattern_[pause_pattern_idx_].delay) { |
| 260 // Do Pause | 259 // Do Pause |
| 261 media_clock_device_->SetRate(0.0); | 260 media_clock_device_->SetRate(0.0); |
| 262 pause_time_ = media_clock_device_->GetTime(); | 261 pause_time_ = media_clock_device_->GetTime(); |
| 263 | 262 |
| 264 VLOG(2) << "Pausing at " << pause_time_.InMilliseconds() << "ms for " << | 263 VLOG(2) << "Pausing at " << pause_time_.InMilliseconds() << "ms for " << |
| 265 pause_pattern_[pause_pattern_idx_].length.InMilliseconds() << "ms"; | 264 pause_pattern_[pause_pattern_idx_].length.InMilliseconds() << "ms"; |
| 266 | 265 |
| 267 // Wait for pause finish | 266 // Wait for pause finish |
| 268 base::MessageLoopProxy::current()->PostDelayedTask( | 267 base::ThreadTaskRunnerHandle::Get()->PostDelayedTask( |
| 269 FROM_HERE, | 268 FROM_HERE, base::Bind(&AudioVideoPipelineDeviceTest::OnPauseCompleted, |
| 270 base::Bind(&AudioVideoPipelineDeviceTest::OnPauseCompleted, | 269 base::Unretained(this)), |
| 271 base::Unretained(this)), | |
| 272 pause_pattern_[pause_pattern_idx_].length); | 270 pause_pattern_[pause_pattern_idx_].length); |
| 273 return; | 271 return; |
| 274 } | 272 } |
| 275 | 273 |
| 276 // Check state again in a little while | 274 // Check state again in a little while |
| 277 base::MessageLoopProxy::current()->PostDelayedTask( | 275 base::ThreadTaskRunnerHandle::Get()->PostDelayedTask( |
| 278 FROM_HERE, | 276 FROM_HERE, base::Bind(&AudioVideoPipelineDeviceTest::MonitorLoop, |
| 279 base::Bind(&AudioVideoPipelineDeviceTest::MonitorLoop, | 277 base::Unretained(this)), |
| 280 base::Unretained(this)), | |
| 281 kMonitorLoopDelay); | 278 kMonitorLoopDelay); |
| 282 } | 279 } |
| 283 | 280 |
| 284 void AudioVideoPipelineDeviceTest::OnPauseCompleted() { | 281 void AudioVideoPipelineDeviceTest::OnPauseCompleted() { |
| 285 // Make sure the media time didn't move during that time. | 282 // Make sure the media time didn't move during that time. |
| 286 base::TimeDelta media_time = media_clock_device_->GetTime(); | 283 base::TimeDelta media_time = media_clock_device_->GetTime(); |
| 287 | 284 |
| 288 // TODO(damienv): | 285 // TODO(damienv): |
| 289 // Should be: | 286 // Should be: |
| 290 // EXPECT_EQ(media_time, media_time_); | 287 // EXPECT_EQ(media_time, media_time_); |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 383 TEST_F(AudioVideoPipelineDeviceTest, WebmPlayback) { | 380 TEST_F(AudioVideoPipelineDeviceTest, WebmPlayback) { |
| 384 scoped_ptr<base::MessageLoop> message_loop(new base::MessageLoop()); | 381 scoped_ptr<base::MessageLoop> message_loop(new base::MessageLoop()); |
| 385 | 382 |
| 386 ConfigureForFile("bear-640x360.webm"); | 383 ConfigureForFile("bear-640x360.webm"); |
| 387 Start(); | 384 Start(); |
| 388 message_loop->Run(); | 385 message_loop->Run(); |
| 389 } | 386 } |
| 390 | 387 |
| 391 } // namespace media | 388 } // namespace media |
| 392 } // namespace chromecast | 389 } // namespace chromecast |
| OLD | NEW |