OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/stl_util.h" | 9 #include "base/stl_util.h" |
10 #include "base/test/simple_test_tick_clock.h" | 10 #include "base/test/simple_test_tick_clock.h" |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
59 class CallbackHelper { | 59 class CallbackHelper { |
60 public: | 60 public: |
61 CallbackHelper() {} | 61 CallbackHelper() {} |
62 virtual ~CallbackHelper() {} | 62 virtual ~CallbackHelper() {} |
63 | 63 |
64 MOCK_METHOD1(OnStart, void(PipelineStatus)); | 64 MOCK_METHOD1(OnStart, void(PipelineStatus)); |
65 MOCK_METHOD1(OnSeek, void(PipelineStatus)); | 65 MOCK_METHOD1(OnSeek, void(PipelineStatus)); |
66 MOCK_METHOD0(OnStop, void()); | 66 MOCK_METHOD0(OnStop, void()); |
67 MOCK_METHOD0(OnEnded, void()); | 67 MOCK_METHOD0(OnEnded, void()); |
68 MOCK_METHOD1(OnError, void(PipelineStatus)); | 68 MOCK_METHOD1(OnError, void(PipelineStatus)); |
69 MOCK_METHOD1(OnMetadata, void(PipelineMetadata)); | 69 MOCK_METHOD1(OnBufferingState, void(Pipeline::BufferingState)); |
70 MOCK_METHOD0(OnPrerollCompleted, void()); | |
71 MOCK_METHOD0(OnDurationChange, void()); | 70 MOCK_METHOD0(OnDurationChange, void()); |
72 | 71 |
73 private: | 72 private: |
74 DISALLOW_COPY_AND_ASSIGN(CallbackHelper); | 73 DISALLOW_COPY_AND_ASSIGN(CallbackHelper); |
75 }; | 74 }; |
76 | 75 |
77 // TODO(scherkus): even though some filters are initialized on separate | 76 // TODO(scherkus): even though some filters are initialized on separate |
78 // threads these test aren't flaky... why? It's because filters' Initialize() | 77 // threads these test aren't flaky... why? It's because filters' Initialize() |
79 // is executed on |message_loop_| and the mock filters instantly call | 78 // is executed on |message_loop_| and the mock filters instantly call |
80 // InitializationComplete(), which keeps the pipeline humming along. If | 79 // InitializationComplete(), which keeps the pipeline humming along. If |
(...skipping 116 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
197 static_cast<DemuxerHost*>(pipeline_.get())->AddTextStream(text_stream(), | 196 static_cast<DemuxerHost*>(pipeline_.get())->AddTextStream(text_stream(), |
198 TextTrackConfig(kTextSubtitles, "", "", "")); | 197 TextTrackConfig(kTextSubtitles, "", "", "")); |
199 } | 198 } |
200 | 199 |
201 // Sets up expectations on the callback and initializes the pipeline. Called | 200 // Sets up expectations on the callback and initializes the pipeline. Called |
202 // after tests have set expectations any filters they wish to use. | 201 // after tests have set expectations any filters they wish to use. |
203 void InitializePipeline(PipelineStatus start_status) { | 202 void InitializePipeline(PipelineStatus start_status) { |
204 EXPECT_CALL(callbacks_, OnStart(start_status)); | 203 EXPECT_CALL(callbacks_, OnStart(start_status)); |
205 | 204 |
206 if (start_status == PIPELINE_OK) { | 205 if (start_status == PIPELINE_OK) { |
207 EXPECT_CALL(callbacks_, OnMetadata(_)).WillOnce(SaveArg<0>(&metadata_)); | 206 EXPECT_CALL(callbacks_, OnBufferingState(Pipeline::kHaveMetadata)); |
208 | 207 |
209 if (audio_stream_) { | 208 if (audio_stream_) { |
210 EXPECT_CALL(*audio_renderer_, SetPlaybackRate(0.0f)); | 209 EXPECT_CALL(*audio_renderer_, SetPlaybackRate(0.0f)); |
211 EXPECT_CALL(*audio_renderer_, SetVolume(1.0f)); | 210 EXPECT_CALL(*audio_renderer_, SetVolume(1.0f)); |
212 | 211 |
213 // Startup sequence. | 212 // Startup sequence. |
214 EXPECT_CALL(*audio_renderer_, Preroll(base::TimeDelta(), _)) | 213 EXPECT_CALL(*audio_renderer_, Preroll(base::TimeDelta(), _)) |
215 .WillOnce(RunCallback<1>(PIPELINE_OK)); | 214 .WillOnce(RunCallback<1>(PIPELINE_OK)); |
216 EXPECT_CALL(*audio_renderer_, Play(_)) | 215 EXPECT_CALL(*audio_renderer_, Play(_)) |
217 .WillOnce(RunClosure<0>()); | 216 .WillOnce(RunClosure<0>()); |
218 } | 217 } |
219 EXPECT_CALL(callbacks_, OnPrerollCompleted()); | 218 EXPECT_CALL(callbacks_, OnBufferingState(Pipeline::kPrerollCompleted)); |
220 } | 219 } |
221 | 220 |
222 pipeline_->Start( | 221 pipeline_->Start( |
223 filter_collection_.Pass(), | 222 filter_collection_.Pass(), |
224 base::Bind(&CallbackHelper::OnEnded, base::Unretained(&callbacks_)), | 223 base::Bind(&CallbackHelper::OnEnded, base::Unretained(&callbacks_)), |
225 base::Bind(&CallbackHelper::OnError, base::Unretained(&callbacks_)), | 224 base::Bind(&CallbackHelper::OnError, base::Unretained(&callbacks_)), |
226 base::Bind(&CallbackHelper::OnStart, base::Unretained(&callbacks_)), | 225 base::Bind(&CallbackHelper::OnStart, base::Unretained(&callbacks_)), |
227 base::Bind(&CallbackHelper::OnMetadata, base::Unretained(&callbacks_)), | 226 base::Bind(&CallbackHelper::OnBufferingState, |
228 base::Bind(&CallbackHelper::OnPrerollCompleted, | |
229 base::Unretained(&callbacks_)), | 227 base::Unretained(&callbacks_)), |
230 base::Bind(&CallbackHelper::OnDurationChange, | 228 base::Bind(&CallbackHelper::OnDurationChange, |
231 base::Unretained(&callbacks_))); | 229 base::Unretained(&callbacks_))); |
232 message_loop_.RunUntilIdle(); | 230 message_loop_.RunUntilIdle(); |
233 } | 231 } |
234 | 232 |
235 void CreateAudioStream() { | 233 void CreateAudioStream() { |
236 audio_stream_ = CreateStream(DemuxerStream::AUDIO); | 234 audio_stream_ = CreateStream(DemuxerStream::AUDIO); |
237 } | 235 } |
238 | 236 |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
281 .WillOnce(RunClosure<0>()); | 279 .WillOnce(RunClosure<0>()); |
282 EXPECT_CALL(*video_renderer_, Flush(_)) | 280 EXPECT_CALL(*video_renderer_, Flush(_)) |
283 .WillOnce(RunClosure<0>()); | 281 .WillOnce(RunClosure<0>()); |
284 EXPECT_CALL(*video_renderer_, Preroll(seek_time, _)) | 282 EXPECT_CALL(*video_renderer_, Preroll(seek_time, _)) |
285 .WillOnce(RunCallback<1>(PIPELINE_OK)); | 283 .WillOnce(RunCallback<1>(PIPELINE_OK)); |
286 EXPECT_CALL(*video_renderer_, SetPlaybackRate(_)); | 284 EXPECT_CALL(*video_renderer_, SetPlaybackRate(_)); |
287 EXPECT_CALL(*video_renderer_, Play(_)) | 285 EXPECT_CALL(*video_renderer_, Play(_)) |
288 .WillOnce(RunClosure<0>()); | 286 .WillOnce(RunClosure<0>()); |
289 } | 287 } |
290 | 288 |
291 EXPECT_CALL(callbacks_, OnPrerollCompleted()); | 289 EXPECT_CALL(callbacks_, OnBufferingState(Pipeline::kPrerollCompleted)); |
292 | 290 |
293 // We expect a successful seek callback. | 291 // We expect a successful seek callback. |
294 EXPECT_CALL(callbacks_, OnSeek(PIPELINE_OK)); | 292 EXPECT_CALL(callbacks_, OnSeek(PIPELINE_OK)); |
295 } | 293 } |
296 | 294 |
297 void DoSeek(const base::TimeDelta& seek_time) { | 295 void DoSeek(const base::TimeDelta& seek_time) { |
298 pipeline_->Seek(seek_time, | 296 pipeline_->Seek(seek_time, |
299 base::Bind(&CallbackHelper::OnSeek, | 297 base::Bind(&CallbackHelper::OnSeek, |
300 base::Unretained(&callbacks_))); | 298 base::Unretained(&callbacks_))); |
301 | 299 |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
335 scoped_ptr<MockDemuxer> demuxer_; | 333 scoped_ptr<MockDemuxer> demuxer_; |
336 MockVideoRenderer* video_renderer_; | 334 MockVideoRenderer* video_renderer_; |
337 MockAudioRenderer* audio_renderer_; | 335 MockAudioRenderer* audio_renderer_; |
338 StrictMock<CallbackHelper> text_renderer_callbacks_; | 336 StrictMock<CallbackHelper> text_renderer_callbacks_; |
339 TextRenderer* text_renderer_; | 337 TextRenderer* text_renderer_; |
340 scoped_ptr<StrictMock<MockDemuxerStream> > audio_stream_; | 338 scoped_ptr<StrictMock<MockDemuxerStream> > audio_stream_; |
341 scoped_ptr<StrictMock<MockDemuxerStream> > video_stream_; | 339 scoped_ptr<StrictMock<MockDemuxerStream> > video_stream_; |
342 scoped_ptr<FakeTextTrackStream> text_stream_; | 340 scoped_ptr<FakeTextTrackStream> text_stream_; |
343 AudioRenderer::TimeCB audio_time_cb_; | 341 AudioRenderer::TimeCB audio_time_cb_; |
344 VideoDecoderConfig video_decoder_config_; | 342 VideoDecoderConfig video_decoder_config_; |
345 PipelineMetadata metadata_; | |
346 | 343 |
347 private: | 344 private: |
348 DISALLOW_COPY_AND_ASSIGN(PipelineTest); | 345 DISALLOW_COPY_AND_ASSIGN(PipelineTest); |
349 }; | 346 }; |
350 | 347 |
351 // Test that playback controls methods no-op when the pipeline hasn't been | 348 // Test that playback controls methods no-op when the pipeline hasn't been |
352 // started. | 349 // started. |
353 TEST_F(PipelineTest, NotStarted) { | 350 TEST_F(PipelineTest, NotStarted) { |
354 const base::TimeDelta kZero; | 351 const base::TimeDelta kZero; |
355 | 352 |
356 EXPECT_FALSE(pipeline_->IsRunning()); | 353 EXPECT_FALSE(pipeline_->IsRunning()); |
| 354 EXPECT_FALSE(pipeline_->HasAudio()); |
| 355 EXPECT_FALSE(pipeline_->HasVideo()); |
357 | 356 |
358 // Setting should still work. | 357 // Setting should still work. |
359 EXPECT_EQ(0.0f, pipeline_->GetPlaybackRate()); | 358 EXPECT_EQ(0.0f, pipeline_->GetPlaybackRate()); |
360 pipeline_->SetPlaybackRate(-1.0f); | 359 pipeline_->SetPlaybackRate(-1.0f); |
361 EXPECT_EQ(0.0f, pipeline_->GetPlaybackRate()); | 360 EXPECT_EQ(0.0f, pipeline_->GetPlaybackRate()); |
362 pipeline_->SetPlaybackRate(1.0f); | 361 pipeline_->SetPlaybackRate(1.0f); |
363 EXPECT_EQ(1.0f, pipeline_->GetPlaybackRate()); | 362 EXPECT_EQ(1.0f, pipeline_->GetPlaybackRate()); |
364 | 363 |
365 // Setting should still work. | 364 // Setting should still work. |
366 EXPECT_EQ(1.0f, pipeline_->GetVolume()); | 365 EXPECT_EQ(1.0f, pipeline_->GetVolume()); |
367 pipeline_->SetVolume(-1.0f); | 366 pipeline_->SetVolume(-1.0f); |
368 EXPECT_EQ(1.0f, pipeline_->GetVolume()); | 367 EXPECT_EQ(1.0f, pipeline_->GetVolume()); |
369 pipeline_->SetVolume(0.0f); | 368 pipeline_->SetVolume(0.0f); |
370 EXPECT_EQ(0.0f, pipeline_->GetVolume()); | 369 EXPECT_EQ(0.0f, pipeline_->GetVolume()); |
371 | 370 |
372 EXPECT_TRUE(kZero == pipeline_->GetMediaTime()); | 371 EXPECT_TRUE(kZero == pipeline_->GetMediaTime()); |
373 EXPECT_EQ(0u, pipeline_->GetBufferedTimeRanges().size()); | 372 EXPECT_EQ(0u, pipeline_->GetBufferedTimeRanges().size()); |
374 EXPECT_TRUE(kZero == pipeline_->GetMediaDuration()); | 373 EXPECT_TRUE(kZero == pipeline_->GetMediaDuration()); |
375 | 374 |
376 EXPECT_EQ(0, pipeline_->GetTotalBytes()); | 375 EXPECT_EQ(0, pipeline_->GetTotalBytes()); |
| 376 |
| 377 // Should always be zero. |
| 378 gfx::Size size = pipeline_->GetInitialNaturalSize(); |
| 379 EXPECT_EQ(0, size.width()); |
| 380 EXPECT_EQ(0, size.height()); |
377 } | 381 } |
378 | 382 |
379 TEST_F(PipelineTest, NeverInitializes) { | 383 TEST_F(PipelineTest, NeverInitializes) { |
380 // Don't execute the callback passed into Initialize(). | 384 // Don't execute the callback passed into Initialize(). |
381 EXPECT_CALL(*demuxer_, Initialize(_, _, _)); | 385 EXPECT_CALL(*demuxer_, Initialize(_, _, _)); |
382 | 386 |
383 // This test hangs during initialization by never calling | 387 // This test hangs during initialization by never calling |
384 // InitializationComplete(). StrictMock<> will ensure that the callback is | 388 // InitializationComplete(). StrictMock<> will ensure that the callback is |
385 // never executed. | 389 // never executed. |
386 pipeline_->Start( | 390 pipeline_->Start( |
387 filter_collection_.Pass(), | 391 filter_collection_.Pass(), |
388 base::Bind(&CallbackHelper::OnEnded, base::Unretained(&callbacks_)), | 392 base::Bind(&CallbackHelper::OnEnded, base::Unretained(&callbacks_)), |
389 base::Bind(&CallbackHelper::OnError, base::Unretained(&callbacks_)), | 393 base::Bind(&CallbackHelper::OnError, base::Unretained(&callbacks_)), |
390 base::Bind(&CallbackHelper::OnStart, base::Unretained(&callbacks_)), | 394 base::Bind(&CallbackHelper::OnStart, base::Unretained(&callbacks_)), |
391 base::Bind(&CallbackHelper::OnMetadata, base::Unretained(&callbacks_)), | 395 base::Bind(&CallbackHelper::OnBufferingState, |
392 base::Bind(&CallbackHelper::OnPrerollCompleted, | |
393 base::Unretained(&callbacks_)), | 396 base::Unretained(&callbacks_)), |
394 base::Bind(&CallbackHelper::OnDurationChange, | 397 base::Bind(&CallbackHelper::OnDurationChange, |
395 base::Unretained(&callbacks_))); | 398 base::Unretained(&callbacks_))); |
396 message_loop_.RunUntilIdle(); | 399 message_loop_.RunUntilIdle(); |
397 | 400 |
398 | 401 |
399 // Because our callback will get executed when the test tears down, we'll | 402 // Because our callback will get executed when the test tears down, we'll |
400 // verify that nothing has been called, then set our expectation for the call | 403 // verify that nothing has been called, then set our expectation for the call |
401 // made during tear down. | 404 // made during tear down. |
402 Mock::VerifyAndClear(&callbacks_); | 405 Mock::VerifyAndClear(&callbacks_); |
(...skipping 20 matching lines...) Expand all Loading... |
423 | 426 |
424 TEST_F(PipelineTest, AudioStream) { | 427 TEST_F(PipelineTest, AudioStream) { |
425 CreateAudioStream(); | 428 CreateAudioStream(); |
426 MockDemuxerStreamVector streams; | 429 MockDemuxerStreamVector streams; |
427 streams.push_back(audio_stream()); | 430 streams.push_back(audio_stream()); |
428 | 431 |
429 InitializeDemuxer(&streams); | 432 InitializeDemuxer(&streams); |
430 InitializeAudioRenderer(audio_stream(), false); | 433 InitializeAudioRenderer(audio_stream(), false); |
431 | 434 |
432 InitializePipeline(PIPELINE_OK); | 435 InitializePipeline(PIPELINE_OK); |
433 EXPECT_TRUE(metadata_.has_audio); | 436 EXPECT_TRUE(pipeline_->HasAudio()); |
434 EXPECT_FALSE(metadata_.has_video); | 437 EXPECT_FALSE(pipeline_->HasVideo()); |
435 } | 438 } |
436 | 439 |
437 TEST_F(PipelineTest, VideoStream) { | 440 TEST_F(PipelineTest, VideoStream) { |
438 CreateVideoStream(); | 441 CreateVideoStream(); |
439 MockDemuxerStreamVector streams; | 442 MockDemuxerStreamVector streams; |
440 streams.push_back(video_stream()); | 443 streams.push_back(video_stream()); |
441 | 444 |
442 InitializeDemuxer(&streams); | 445 InitializeDemuxer(&streams); |
443 InitializeVideoRenderer(video_stream()); | 446 InitializeVideoRenderer(video_stream()); |
444 | 447 |
445 InitializePipeline(PIPELINE_OK); | 448 InitializePipeline(PIPELINE_OK); |
446 EXPECT_FALSE(metadata_.has_audio); | 449 EXPECT_FALSE(pipeline_->HasAudio()); |
447 EXPECT_TRUE(metadata_.has_video); | 450 EXPECT_TRUE(pipeline_->HasVideo()); |
448 } | 451 } |
449 | 452 |
450 TEST_F(PipelineTest, AudioVideoStream) { | 453 TEST_F(PipelineTest, AudioVideoStream) { |
451 CreateAudioStream(); | 454 CreateAudioStream(); |
452 CreateVideoStream(); | 455 CreateVideoStream(); |
453 MockDemuxerStreamVector streams; | 456 MockDemuxerStreamVector streams; |
454 streams.push_back(audio_stream()); | 457 streams.push_back(audio_stream()); |
455 streams.push_back(video_stream()); | 458 streams.push_back(video_stream()); |
456 | 459 |
457 InitializeDemuxer(&streams); | 460 InitializeDemuxer(&streams); |
458 InitializeAudioRenderer(audio_stream(), false); | 461 InitializeAudioRenderer(audio_stream(), false); |
459 InitializeVideoRenderer(video_stream()); | 462 InitializeVideoRenderer(video_stream()); |
460 | 463 |
461 InitializePipeline(PIPELINE_OK); | 464 InitializePipeline(PIPELINE_OK); |
462 EXPECT_TRUE(metadata_.has_audio); | 465 EXPECT_TRUE(pipeline_->HasAudio()); |
463 EXPECT_TRUE(metadata_.has_video); | 466 EXPECT_TRUE(pipeline_->HasVideo()); |
464 } | 467 } |
465 | 468 |
466 TEST_F(PipelineTest, VideoTextStream) { | 469 TEST_F(PipelineTest, VideoTextStream) { |
467 CreateVideoStream(); | 470 CreateVideoStream(); |
468 CreateTextStream(); | 471 CreateTextStream(); |
469 MockDemuxerStreamVector streams; | 472 MockDemuxerStreamVector streams; |
470 streams.push_back(video_stream()); | 473 streams.push_back(video_stream()); |
471 | 474 |
472 InitializeDemuxer(&streams); | 475 InitializeDemuxer(&streams); |
473 InitializeVideoRenderer(video_stream()); | 476 InitializeVideoRenderer(video_stream()); |
474 | 477 |
475 InitializePipeline(PIPELINE_OK); | 478 InitializePipeline(PIPELINE_OK); |
476 EXPECT_FALSE(metadata_.has_audio); | 479 EXPECT_FALSE(pipeline_->HasAudio()); |
477 EXPECT_TRUE(metadata_.has_video); | 480 EXPECT_TRUE(pipeline_->HasVideo()); |
478 | 481 |
479 AddTextStream(); | 482 AddTextStream(); |
480 message_loop_.RunUntilIdle(); | 483 message_loop_.RunUntilIdle(); |
481 } | 484 } |
482 | 485 |
483 TEST_F(PipelineTest, VideoAudioTextStream) { | 486 TEST_F(PipelineTest, VideoAudioTextStream) { |
484 CreateVideoStream(); | 487 CreateVideoStream(); |
485 CreateAudioStream(); | 488 CreateAudioStream(); |
486 CreateTextStream(); | 489 CreateTextStream(); |
487 MockDemuxerStreamVector streams; | 490 MockDemuxerStreamVector streams; |
488 streams.push_back(video_stream()); | 491 streams.push_back(video_stream()); |
489 streams.push_back(audio_stream()); | 492 streams.push_back(audio_stream()); |
490 | 493 |
491 InitializeDemuxer(&streams); | 494 InitializeDemuxer(&streams); |
492 InitializeVideoRenderer(video_stream()); | 495 InitializeVideoRenderer(video_stream()); |
493 InitializeAudioRenderer(audio_stream(), false); | 496 InitializeAudioRenderer(audio_stream(), false); |
494 | 497 |
495 InitializePipeline(PIPELINE_OK); | 498 InitializePipeline(PIPELINE_OK); |
496 EXPECT_TRUE(metadata_.has_audio); | 499 EXPECT_TRUE(pipeline_->HasAudio()); |
497 EXPECT_TRUE(metadata_.has_video); | 500 EXPECT_TRUE(pipeline_->HasVideo()); |
498 | 501 |
499 AddTextStream(); | 502 AddTextStream(); |
500 message_loop_.RunUntilIdle(); | 503 message_loop_.RunUntilIdle(); |
501 } | 504 } |
502 | 505 |
503 TEST_F(PipelineTest, Seek) { | 506 TEST_F(PipelineTest, Seek) { |
504 CreateAudioStream(); | 507 CreateAudioStream(); |
505 CreateVideoStream(); | 508 CreateVideoStream(); |
506 CreateTextStream(); | 509 CreateTextStream(); |
507 MockDemuxerStreamVector streams; | 510 MockDemuxerStreamVector streams; |
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
613 CreateVideoStream(); | 616 CreateVideoStream(); |
614 MockDemuxerStreamVector streams; | 617 MockDemuxerStreamVector streams; |
615 streams.push_back(audio_stream()); | 618 streams.push_back(audio_stream()); |
616 streams.push_back(video_stream()); | 619 streams.push_back(video_stream()); |
617 | 620 |
618 InitializeDemuxer(&streams); | 621 InitializeDemuxer(&streams); |
619 InitializeAudioRenderer(audio_stream(), false); | 622 InitializeAudioRenderer(audio_stream(), false); |
620 InitializeVideoRenderer(video_stream()); | 623 InitializeVideoRenderer(video_stream()); |
621 | 624 |
622 InitializePipeline(PIPELINE_OK); | 625 InitializePipeline(PIPELINE_OK); |
623 EXPECT_TRUE(metadata_.has_audio); | 626 EXPECT_TRUE(pipeline_->HasAudio()); |
624 EXPECT_TRUE(metadata_.has_video); | 627 EXPECT_TRUE(pipeline_->HasVideo()); |
625 | 628 |
626 EXPECT_CALL(*demuxer_, OnAudioRendererDisabled()); | 629 EXPECT_CALL(*demuxer_, OnAudioRendererDisabled()); |
627 pipeline_->OnAudioDisabled(); | 630 pipeline_->OnAudioDisabled(); |
628 | 631 |
629 // Verify that ended event is fired when video ends. | 632 // Verify that ended event is fired when video ends. |
630 EXPECT_CALL(callbacks_, OnEnded()); | 633 EXPECT_CALL(callbacks_, OnEnded()); |
631 pipeline_->OnVideoRendererEnded(); | 634 pipeline_->OnVideoRendererEnded(); |
632 } | 635 } |
633 | 636 |
634 TEST_F(PipelineTest, DisableAudioRendererDuringInit) { | 637 TEST_F(PipelineTest, DisableAudioRendererDuringInit) { |
635 CreateAudioStream(); | 638 CreateAudioStream(); |
636 CreateVideoStream(); | 639 CreateVideoStream(); |
637 MockDemuxerStreamVector streams; | 640 MockDemuxerStreamVector streams; |
638 streams.push_back(audio_stream()); | 641 streams.push_back(audio_stream()); |
639 streams.push_back(video_stream()); | 642 streams.push_back(video_stream()); |
640 | 643 |
641 InitializeDemuxer(&streams); | 644 InitializeDemuxer(&streams); |
642 InitializeAudioRenderer(audio_stream(), true); | 645 InitializeAudioRenderer(audio_stream(), true); |
643 InitializeVideoRenderer(video_stream()); | 646 InitializeVideoRenderer(video_stream()); |
644 | 647 |
645 EXPECT_CALL(*demuxer_, OnAudioRendererDisabled()); | 648 EXPECT_CALL(*demuxer_, OnAudioRendererDisabled()); |
646 | 649 |
647 InitializePipeline(PIPELINE_OK); | 650 InitializePipeline(PIPELINE_OK); |
648 EXPECT_TRUE(metadata_.has_audio); | 651 EXPECT_FALSE(pipeline_->HasAudio()); |
649 EXPECT_TRUE(metadata_.has_video); | 652 EXPECT_TRUE(pipeline_->HasVideo()); |
650 | 653 |
651 // Verify that ended event is fired when video ends. | 654 // Verify that ended event is fired when video ends. |
652 EXPECT_CALL(callbacks_, OnEnded()); | 655 EXPECT_CALL(callbacks_, OnEnded()); |
653 pipeline_->OnVideoRendererEnded(); | 656 pipeline_->OnVideoRendererEnded(); |
654 } | 657 } |
655 | 658 |
656 TEST_F(PipelineTest, EndedCallback) { | 659 TEST_F(PipelineTest, EndedCallback) { |
657 CreateAudioStream(); | 660 CreateAudioStream(); |
658 CreateVideoStream(); | 661 CreateVideoStream(); |
659 CreateTextStream(); | 662 CreateTextStream(); |
(...skipping 161 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
821 TEST_F(PipelineTest, StartTimeIsZero) { | 824 TEST_F(PipelineTest, StartTimeIsZero) { |
822 CreateVideoStream(); | 825 CreateVideoStream(); |
823 MockDemuxerStreamVector streams; | 826 MockDemuxerStreamVector streams; |
824 streams.push_back(video_stream()); | 827 streams.push_back(video_stream()); |
825 | 828 |
826 const base::TimeDelta kDuration = base::TimeDelta::FromSeconds(100); | 829 const base::TimeDelta kDuration = base::TimeDelta::FromSeconds(100); |
827 InitializeDemuxer(&streams, kDuration); | 830 InitializeDemuxer(&streams, kDuration); |
828 InitializeVideoRenderer(video_stream()); | 831 InitializeVideoRenderer(video_stream()); |
829 | 832 |
830 InitializePipeline(PIPELINE_OK); | 833 InitializePipeline(PIPELINE_OK); |
831 EXPECT_FALSE(metadata_.has_audio); | 834 EXPECT_FALSE(pipeline_->HasAudio()); |
832 EXPECT_TRUE(metadata_.has_video); | 835 EXPECT_TRUE(pipeline_->HasVideo()); |
833 | 836 |
834 EXPECT_EQ(base::TimeDelta(), pipeline_->GetMediaTime()); | 837 EXPECT_EQ(base::TimeDelta(), pipeline_->GetMediaTime()); |
835 } | 838 } |
836 | 839 |
837 TEST_F(PipelineTest, StartTimeIsNonZero) { | 840 TEST_F(PipelineTest, StartTimeIsNonZero) { |
838 const base::TimeDelta kStartTime = base::TimeDelta::FromSeconds(4); | 841 const base::TimeDelta kStartTime = base::TimeDelta::FromSeconds(4); |
839 const base::TimeDelta kDuration = base::TimeDelta::FromSeconds(100); | 842 const base::TimeDelta kDuration = base::TimeDelta::FromSeconds(100); |
840 | 843 |
841 EXPECT_CALL(*demuxer_, GetStartTime()) | 844 EXPECT_CALL(*demuxer_, GetStartTime()) |
842 .WillRepeatedly(Return(kStartTime)); | 845 .WillRepeatedly(Return(kStartTime)); |
843 | 846 |
844 CreateVideoStream(); | 847 CreateVideoStream(); |
845 MockDemuxerStreamVector streams; | 848 MockDemuxerStreamVector streams; |
846 streams.push_back(video_stream()); | 849 streams.push_back(video_stream()); |
847 | 850 |
848 InitializeDemuxer(&streams, kDuration); | 851 InitializeDemuxer(&streams, kDuration); |
849 InitializeVideoRenderer(video_stream()); | 852 InitializeVideoRenderer(video_stream()); |
850 | 853 |
851 InitializePipeline(PIPELINE_OK); | 854 InitializePipeline(PIPELINE_OK); |
852 EXPECT_FALSE(metadata_.has_audio); | 855 EXPECT_FALSE(pipeline_->HasAudio()); |
853 EXPECT_TRUE(metadata_.has_video); | 856 EXPECT_TRUE(pipeline_->HasVideo()); |
854 | 857 |
855 EXPECT_EQ(kStartTime, pipeline_->GetMediaTime()); | 858 EXPECT_EQ(kStartTime, pipeline_->GetMediaTime()); |
856 } | 859 } |
857 | 860 |
858 static void RunTimeCB(const AudioRenderer::TimeCB& time_cb, | 861 static void RunTimeCB(const AudioRenderer::TimeCB& time_cb, |
859 int time_in_ms, | 862 int time_in_ms, |
860 int max_time_in_ms) { | 863 int max_time_in_ms) { |
861 time_cb.Run(base::TimeDelta::FromMilliseconds(time_in_ms), | 864 time_cb.Run(base::TimeDelta::FromMilliseconds(time_in_ms), |
862 base::TimeDelta::FromMilliseconds(max_time_in_ms)); | 865 base::TimeDelta::FromMilliseconds(max_time_in_ms)); |
863 } | 866 } |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
895 .WillOnce(RunClosure<0>()); | 898 .WillOnce(RunClosure<0>()); |
896 EXPECT_CALL(*audio_renderer_, Flush(_)) | 899 EXPECT_CALL(*audio_renderer_, Flush(_)) |
897 .WillOnce(RunClosure<0>()); | 900 .WillOnce(RunClosure<0>()); |
898 EXPECT_CALL(*audio_renderer_, Preroll(seek_time, _)) | 901 EXPECT_CALL(*audio_renderer_, Preroll(seek_time, _)) |
899 .WillOnce(RunCallback<1>(PIPELINE_OK)); | 902 .WillOnce(RunCallback<1>(PIPELINE_OK)); |
900 EXPECT_CALL(*audio_renderer_, SetPlaybackRate(_)); | 903 EXPECT_CALL(*audio_renderer_, SetPlaybackRate(_)); |
901 EXPECT_CALL(*audio_renderer_, SetVolume(_)); | 904 EXPECT_CALL(*audio_renderer_, SetVolume(_)); |
902 EXPECT_CALL(*audio_renderer_, Play(_)) | 905 EXPECT_CALL(*audio_renderer_, Play(_)) |
903 .WillOnce(RunClosure<0>()); | 906 .WillOnce(RunClosure<0>()); |
904 | 907 |
905 EXPECT_CALL(callbacks_, OnPrerollCompleted()); | 908 EXPECT_CALL(callbacks_, OnBufferingState(Pipeline::kPrerollCompleted)); |
906 EXPECT_CALL(callbacks_, OnSeek(PIPELINE_OK)); | 909 EXPECT_CALL(callbacks_, OnSeek(PIPELINE_OK)); |
907 DoSeek(seek_time); | 910 DoSeek(seek_time); |
908 | 911 |
909 EXPECT_EQ(pipeline_->GetMediaTime(), seek_time); | 912 EXPECT_EQ(pipeline_->GetMediaTime(), seek_time); |
910 | 913 |
911 // Now that the seek is complete, verify that time updates advance the current | 914 // Now that the seek is complete, verify that time updates advance the current |
912 // time. | 915 // time. |
913 base::TimeDelta new_time = seek_time + base::TimeDelta::FromMilliseconds(100); | 916 base::TimeDelta new_time = seek_time + base::TimeDelta::FromMilliseconds(100); |
914 audio_time_cb_.Run(new_time, new_time); | 917 audio_time_cb_.Run(new_time, new_time); |
915 | 918 |
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
989 void DoInitialize(TeardownState state, StopOrError stop_or_error) { | 992 void DoInitialize(TeardownState state, StopOrError stop_or_error) { |
990 PipelineStatus expected_status = | 993 PipelineStatus expected_status = |
991 SetInitializeExpectations(state, stop_or_error); | 994 SetInitializeExpectations(state, stop_or_error); |
992 | 995 |
993 EXPECT_CALL(callbacks_, OnStart(expected_status)); | 996 EXPECT_CALL(callbacks_, OnStart(expected_status)); |
994 pipeline_->Start( | 997 pipeline_->Start( |
995 filter_collection_.Pass(), | 998 filter_collection_.Pass(), |
996 base::Bind(&CallbackHelper::OnEnded, base::Unretained(&callbacks_)), | 999 base::Bind(&CallbackHelper::OnEnded, base::Unretained(&callbacks_)), |
997 base::Bind(&CallbackHelper::OnError, base::Unretained(&callbacks_)), | 1000 base::Bind(&CallbackHelper::OnError, base::Unretained(&callbacks_)), |
998 base::Bind(&CallbackHelper::OnStart, base::Unretained(&callbacks_)), | 1001 base::Bind(&CallbackHelper::OnStart, base::Unretained(&callbacks_)), |
999 base::Bind(&CallbackHelper::OnMetadata, base::Unretained(&callbacks_)), | 1002 base::Bind(&CallbackHelper::OnBufferingState, |
1000 base::Bind(&CallbackHelper::OnPrerollCompleted, | |
1001 base::Unretained(&callbacks_)), | 1003 base::Unretained(&callbacks_)), |
1002 base::Bind(&CallbackHelper::OnDurationChange, | 1004 base::Bind(&CallbackHelper::OnDurationChange, |
1003 base::Unretained(&callbacks_))); | 1005 base::Unretained(&callbacks_))); |
1004 message_loop_.RunUntilIdle(); | 1006 message_loop_.RunUntilIdle(); |
1005 } | 1007 } |
1006 | 1008 |
1007 PipelineStatus SetInitializeExpectations(TeardownState state, | 1009 PipelineStatus SetInitializeExpectations(TeardownState state, |
1008 StopOrError stop_or_error) { | 1010 StopOrError stop_or_error) { |
1009 PipelineStatus status = PIPELINE_OK; | 1011 PipelineStatus status = PIPELINE_OK; |
1010 base::Closure stop_cb = base::Bind( | 1012 base::Closure stop_cb = base::Bind( |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1067 | 1069 |
1068 EXPECT_CALL(*demuxer_, Stop(_)).WillOnce(RunClosure<0>()); | 1070 EXPECT_CALL(*demuxer_, Stop(_)).WillOnce(RunClosure<0>()); |
1069 EXPECT_CALL(*audio_renderer_, Stop(_)).WillOnce(RunClosure<0>()); | 1071 EXPECT_CALL(*audio_renderer_, Stop(_)).WillOnce(RunClosure<0>()); |
1070 EXPECT_CALL(*video_renderer_, Stop(_)).WillOnce(RunClosure<0>()); | 1072 EXPECT_CALL(*video_renderer_, Stop(_)).WillOnce(RunClosure<0>()); |
1071 return status; | 1073 return status; |
1072 } | 1074 } |
1073 | 1075 |
1074 EXPECT_CALL(*video_renderer_, Initialize(_, _, _, _, _, _, _, _)) | 1076 EXPECT_CALL(*video_renderer_, Initialize(_, _, _, _, _, _, _, _)) |
1075 .WillOnce(RunCallback<1>(PIPELINE_OK)); | 1077 .WillOnce(RunCallback<1>(PIPELINE_OK)); |
1076 | 1078 |
1077 EXPECT_CALL(callbacks_, OnMetadata(_)); | 1079 EXPECT_CALL(callbacks_, OnBufferingState(Pipeline::kHaveMetadata)); |
1078 | 1080 |
1079 // If we get here it's a successful initialization. | 1081 // If we get here it's a successful initialization. |
1080 EXPECT_CALL(*audio_renderer_, Preroll(base::TimeDelta(), _)) | 1082 EXPECT_CALL(*audio_renderer_, Preroll(base::TimeDelta(), _)) |
1081 .WillOnce(RunCallback<1>(PIPELINE_OK)); | 1083 .WillOnce(RunCallback<1>(PIPELINE_OK)); |
1082 EXPECT_CALL(*video_renderer_, Preroll(base::TimeDelta(), _)) | 1084 EXPECT_CALL(*video_renderer_, Preroll(base::TimeDelta(), _)) |
1083 .WillOnce(RunCallback<1>(PIPELINE_OK)); | 1085 .WillOnce(RunCallback<1>(PIPELINE_OK)); |
1084 | 1086 |
1085 EXPECT_CALL(*audio_renderer_, SetPlaybackRate(0.0f)); | 1087 EXPECT_CALL(*audio_renderer_, SetPlaybackRate(0.0f)); |
1086 EXPECT_CALL(*video_renderer_, SetPlaybackRate(0.0f)); | 1088 EXPECT_CALL(*video_renderer_, SetPlaybackRate(0.0f)); |
1087 EXPECT_CALL(*audio_renderer_, SetVolume(1.0f)); | 1089 EXPECT_CALL(*audio_renderer_, SetVolume(1.0f)); |
1088 | 1090 |
1089 EXPECT_CALL(*audio_renderer_, Play(_)) | 1091 EXPECT_CALL(*audio_renderer_, Play(_)) |
1090 .WillOnce(RunClosure<0>()); | 1092 .WillOnce(RunClosure<0>()); |
1091 EXPECT_CALL(*video_renderer_, Play(_)) | 1093 EXPECT_CALL(*video_renderer_, Play(_)) |
1092 .WillOnce(RunClosure<0>()); | 1094 .WillOnce(RunClosure<0>()); |
1093 | 1095 |
1094 if (status == PIPELINE_OK) | 1096 if (status == PIPELINE_OK) |
1095 EXPECT_CALL(callbacks_, OnPrerollCompleted()); | 1097 EXPECT_CALL(callbacks_, OnBufferingState(Pipeline::kPrerollCompleted)); |
1096 | 1098 |
1097 return status; | 1099 return status; |
1098 } | 1100 } |
1099 | 1101 |
1100 void DoSeek(TeardownState state, StopOrError stop_or_error) { | 1102 void DoSeek(TeardownState state, StopOrError stop_or_error) { |
1101 InSequence s; | 1103 InSequence s; |
1102 PipelineStatus status = SetSeekExpectations(state, stop_or_error); | 1104 PipelineStatus status = SetSeekExpectations(state, stop_or_error); |
1103 | 1105 |
1104 EXPECT_CALL(*demuxer_, Stop(_)).WillOnce(RunClosure<0>()); | 1106 EXPECT_CALL(*demuxer_, Stop(_)).WillOnce(RunClosure<0>()); |
1105 EXPECT_CALL(*audio_renderer_, Stop(_)).WillOnce(RunClosure<0>()); | 1107 EXPECT_CALL(*audio_renderer_, Stop(_)).WillOnce(RunClosure<0>()); |
(...skipping 158 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1264 INSTANTIATE_TEARDOWN_TEST(Error, Pausing); | 1266 INSTANTIATE_TEARDOWN_TEST(Error, Pausing); |
1265 INSTANTIATE_TEARDOWN_TEST(Error, Flushing); | 1267 INSTANTIATE_TEARDOWN_TEST(Error, Flushing); |
1266 INSTANTIATE_TEARDOWN_TEST(Error, Seeking); | 1268 INSTANTIATE_TEARDOWN_TEST(Error, Seeking); |
1267 INSTANTIATE_TEARDOWN_TEST(Error, Prerolling); | 1269 INSTANTIATE_TEARDOWN_TEST(Error, Prerolling); |
1268 INSTANTIATE_TEARDOWN_TEST(Error, Starting); | 1270 INSTANTIATE_TEARDOWN_TEST(Error, Starting); |
1269 INSTANTIATE_TEARDOWN_TEST(Error, Playing); | 1271 INSTANTIATE_TEARDOWN_TEST(Error, Playing); |
1270 | 1272 |
1271 INSTANTIATE_TEARDOWN_TEST(ErrorAndStop, Playing); | 1273 INSTANTIATE_TEARDOWN_TEST(ErrorAndStop, Playing); |
1272 | 1274 |
1273 } // namespace media | 1275 } // namespace media |
OLD | NEW |