Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(185)

Side by Side Diff: media/test/pipeline_integration_test.cc

Issue 1624703002: Implement support for vp9 in ISO-BMFF (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add a flag ENABLE_MP4_VP8_VP9_DEMUXING for this change. Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 <stddef.h> 5 #include <stddef.h>
6 #include <stdint.h> 6 #include <stdint.h>
7 #include <utility> 7 #include <utility>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/command_line.h" 10 #include "base/command_line.h"
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "base/memory/ref_counted.h" 12 #include "base/memory/ref_counted.h"
13 #include "base/memory/scoped_ptr.h" 13 #include "base/memory/scoped_ptr.h"
14 #include "base/strings/string_split.h" 14 #include "base/strings/string_split.h"
15 #include "base/strings/string_util.h" 15 #include "base/strings/string_util.h"
16 #include "build/build_config.h" 16 #include "build/build_config.h"
17 #include "media/base/cdm_callback_promise.h" 17 #include "media/base/cdm_callback_promise.h"
18 #include "media/base/cdm_context.h" 18 #include "media/base/cdm_context.h"
19 #include "media/base/cdm_key_information.h" 19 #include "media/base/cdm_key_information.h"
20 #include "media/base/decoder_buffer.h" 20 #include "media/base/decoder_buffer.h"
21 #include "media/base/media.h" 21 #include "media/base/media.h"
22 #include "media/base/media_keys.h" 22 #include "media/base/media_keys.h"
23 #include "media/base/media_switches.h" 23 #include "media/base/media_switches.h"
24 #include "media/base/test_data_util.h" 24 #include "media/base/test_data_util.h"
25 #include "media/base/timestamp_constants.h" 25 #include "media/base/timestamp_constants.h"
26 #include "media/cdm/aes_decryptor.h" 26 #include "media/cdm/aes_decryptor.h"
27 #include "media/cdm/json_web_key.h" 27 #include "media/cdm/json_web_key.h"
28 #include "media/filters/chunk_demuxer.h" 28 #include "media/filters/chunk_demuxer.h"
29 #include "media/media_features.h"
29 #include "media/renderers/renderer_impl.h" 30 #include "media/renderers/renderer_impl.h"
30 #include "media/test/pipeline_integration_test_base.h" 31 #include "media/test/pipeline_integration_test_base.h"
31 #include "testing/gmock/include/gmock/gmock.h" 32 #include "testing/gmock/include/gmock/gmock.h"
32 #include "url/gurl.h" 33 #include "url/gurl.h"
33 34
34 #if defined(MOJO_RENDERER) 35 #if defined(MOJO_RENDERER)
35 #include "media/mojo/interfaces/renderer.mojom.h" 36 #include "media/mojo/interfaces/renderer.mojom.h"
36 #include "media/mojo/interfaces/service_factory.mojom.h" 37 #include "media/mojo/interfaces/service_factory.mojom.h"
37 #include "media/mojo/services/mojo_renderer_impl.h" 38 #include "media/mojo/services/mojo_renderer_impl.h"
38 #include "mojo/shell/public/cpp/application_impl.h" 39 #include "mojo/shell/public/cpp/application_impl.h"
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
71 72
72 const char kWebM[] = "video/webm; codecs=\"vp8,vorbis\""; 73 const char kWebM[] = "video/webm; codecs=\"vp8,vorbis\"";
73 const char kWebMVP9[] = "video/webm; codecs=\"vp9\""; 74 const char kWebMVP9[] = "video/webm; codecs=\"vp9\"";
74 const char kAudioOnlyWebM[] = "video/webm; codecs=\"vorbis\""; 75 const char kAudioOnlyWebM[] = "video/webm; codecs=\"vorbis\"";
75 const char kOpusAudioOnlyWebM[] = "video/webm; codecs=\"opus\""; 76 const char kOpusAudioOnlyWebM[] = "video/webm; codecs=\"opus\"";
76 const char kVideoOnlyWebM[] = "video/webm; codecs=\"vp8\""; 77 const char kVideoOnlyWebM[] = "video/webm; codecs=\"vp8\"";
77 #if defined(USE_PROPRIETARY_CODECS) 78 #if defined(USE_PROPRIETARY_CODECS)
78 const char kADTS[] = "audio/aac"; 79 const char kADTS[] = "audio/aac";
79 const char kMP4[] = "video/mp4; codecs=\"avc1.4D4041,mp4a.40.2\""; 80 const char kMP4[] = "video/mp4; codecs=\"avc1.4D4041,mp4a.40.2\"";
80 const char kMP4VideoAVC3[] = "video/mp4; codecs=\"avc3.64001f\""; 81 const char kMP4VideoAVC3[] = "video/mp4; codecs=\"avc3.64001f\"";
82 #if BUILDFLAG(ENABLE_MP4_VP8_VP9_DEMUXING)
83 const char kMP4VideoVP8[] = "video/mp4; codecs=\"vp08.00.00.08.01.01.00.00\"";
84 const char kMP4VideoVP9[] = "video/mp4; codecs=\"vp08.00.00.08.01.01.00.00\"";
85 #endif
81 #if !defined(DISABLE_EME_TESTS) 86 #if !defined(DISABLE_EME_TESTS)
82 const char kMP4Video[] = "video/mp4; codecs=\"avc1.4D4041\""; 87 const char kMP4Video[] = "video/mp4; codecs=\"avc1.4D4041\"";
83 const char kMP4Audio[] = "audio/mp4; codecs=\"mp4a.40.2\""; 88 const char kMP4Audio[] = "audio/mp4; codecs=\"mp4a.40.2\"";
84 #endif // !defined(DISABLE_EME_TESTS) 89 #endif // !defined(DISABLE_EME_TESTS)
85 const char kMP3[] = "audio/mpeg"; 90 const char kMP3[] = "audio/mpeg";
86 #endif // defined(USE_PROPRIETARY_CODECS) 91 #endif // defined(USE_PROPRIETARY_CODECS)
87 92
88 // Key used to encrypt test files. 93 // Key used to encrypt test files.
89 const uint8_t kSecretKey[] = { 94 const uint8_t kSecretKey[] = {
90 0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b, 95 0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
(...skipping 1623 matching lines...) Expand 10 before | Expand all | Expand 10 after
1714 1719
1715 source.EndOfStream(); 1720 source.EndOfStream();
1716 ASSERT_EQ(PIPELINE_OK, pipeline_status_); 1721 ASSERT_EQ(PIPELINE_OK, pipeline_status_);
1717 1722
1718 Play(); 1723 Play();
1719 1724
1720 ASSERT_TRUE(WaitUntilOnEnded()); 1725 ASSERT_TRUE(WaitUntilOnEnded());
1721 source.Shutdown(); 1726 source.Shutdown();
1722 Stop(); 1727 Stop();
1723 } 1728 }
1729
1730 #if BUILDFLAG(ENABLE_MP4_VP8_VP9_DEMUXING)
1731 TEST_F(PipelineIntegrationTest, EncryptedPlayback_MP4_VP8_CENC_VideoOnly) {
1732 MockMediaSource source("bear-320x240-v_frag-vp8-cenc.mp4", kMP4VideoVP8,
1733 kAppendWholeFile);
1734 FakeEncryptedMedia encrypted_media(new KeyProvidingApp());
1735 StartPipelineWithEncryptedMedia(&source, &encrypted_media);
1736
1737 source.EndOfStream();
1738 ASSERT_EQ(PIPELINE_OK, pipeline_status_);
1739
1740 Play();
1741
1742 ASSERT_TRUE(WaitUntilOnEnded());
1743 source.Shutdown();
1744 Stop();
1745 }
1746
1747 TEST_F(PipelineIntegrationTest, EncryptedPlayback_MP4_VP9_CENC_VideoOnly) {
1748 MockMediaSource source("bear-320x240-v_frag-vp9-cenc.mp4", kMP4VideoVP8,
1749 kAppendWholeFile);
1750 FakeEncryptedMedia encrypted_media(new KeyProvidingApp());
1751 StartPipelineWithEncryptedMedia(&source, &encrypted_media);
1752
1753 source.EndOfStream();
1754 ASSERT_EQ(PIPELINE_OK, pipeline_status_);
1755
1756 Play();
1757
1758 ASSERT_TRUE(WaitUntilOnEnded());
1759 source.Shutdown();
1760 Stop();
1761 }
1762 #endif // #if BUILDFLAG(ENABLE_MP4_VP8_VP9_DEMUXING)
1763
1724 #endif // !defined(DISABLE_EME_TESTS) 1764 #endif // !defined(DISABLE_EME_TESTS)
1725 1765
1726 TEST_F(PipelineIntegrationTest, BasicPlayback_MediaSource_VideoOnly_MP4_AVC3) { 1766 TEST_F(PipelineIntegrationTest, BasicPlayback_MediaSource_VideoOnly_MP4_AVC3) {
1727 MockMediaSource source("bear-1280x720-v_frag-avc3.mp4", kMP4VideoAVC3, 1767 MockMediaSource source("bear-1280x720-v_frag-avc3.mp4", kMP4VideoAVC3,
1728 kAppendWholeFile); 1768 kAppendWholeFile);
1729 StartPipelineWithMediaSource(&source); 1769 StartPipelineWithMediaSource(&source);
1730 source.EndOfStream(); 1770 source.EndOfStream();
1731 1771
1732 EXPECT_EQ(1u, pipeline_->GetBufferedTimeRanges().size()); 1772 EXPECT_EQ(1u, pipeline_->GetBufferedTimeRanges().size());
1733 EXPECT_EQ(0, pipeline_->GetBufferedTimeRanges().start(0).InMilliseconds()); 1773 EXPECT_EQ(0, pipeline_->GetBufferedTimeRanges().start(0).InMilliseconds());
1734 EXPECT_EQ(k1280IsoAVC3FileDurationMs, 1774 EXPECT_EQ(k1280IsoAVC3FileDurationMs,
1735 pipeline_->GetBufferedTimeRanges().end(0).InMilliseconds()); 1775 pipeline_->GetBufferedTimeRanges().end(0).InMilliseconds());
1736 1776
1737 Play(); 1777 Play();
1738 1778
1739 ASSERT_TRUE(WaitUntilOnEnded()); 1779 ASSERT_TRUE(WaitUntilOnEnded());
1740 source.Shutdown(); 1780 source.Shutdown();
1741 Stop(); 1781 Stop();
1742 } 1782 }
1783
1784 #if BUILDFLAG(ENABLE_MP4_VP8_VP9_DEMUXING)
1785 TEST_F(PipelineIntegrationTest, BasicPlayback_MediaSource_VideoOnly_MP4_VP8) {
1786 MockMediaSource source("bear-320x240-v_frag-vp8.mp4", kMP4VideoVP8,
1787 kAppendWholeFile);
1788 StartPipelineWithMediaSource(&source);
1789 source.EndOfStream();
1790 ASSERT_EQ(PIPELINE_OK, pipeline_status_);
1791
1792 Play();
1793
1794 ASSERT_TRUE(WaitUntilOnEnded());
1795 source.Shutdown();
1796 Stop();
1797 }
1798
1799 TEST_F(PipelineIntegrationTest, BasicPlayback_MediaSource_VideoOnly_MP4_VP9) {
1800 MockMediaSource source("bear-320x240-v_frag-vp9.mp4", kMP4VideoVP9,
1801 kAppendWholeFile);
1802 StartPipelineWithMediaSource(&source);
1803 source.EndOfStream();
1804 ASSERT_EQ(PIPELINE_OK, pipeline_status_);
1805
1806 Play();
1807
1808 ASSERT_TRUE(WaitUntilOnEnded());
1809 source.Shutdown();
1810 Stop();
1811 }
1812 #endif // #if BUILDFLAG(ENABLE_MP4_VP8_VP9_DEMUXING)
1813
1743 #endif // defined(USE_PROPRIETARY_CODECS) 1814 #endif // defined(USE_PROPRIETARY_CODECS)
1744 1815
1745 TEST_F(PipelineIntegrationTest, SeekWhilePaused) { 1816 TEST_F(PipelineIntegrationTest, SeekWhilePaused) {
1746 ASSERT_EQ(PIPELINE_OK, Start("bear-320x240.webm")); 1817 ASSERT_EQ(PIPELINE_OK, Start("bear-320x240.webm"));
1747 1818
1748 base::TimeDelta duration(pipeline_->GetMediaDuration()); 1819 base::TimeDelta duration(pipeline_->GetMediaDuration());
1749 base::TimeDelta start_seek_time(duration / 4); 1820 base::TimeDelta start_seek_time(duration / 4);
1750 base::TimeDelta seek_time(duration * 3 / 4); 1821 base::TimeDelta seek_time(duration * 3 / 4);
1751 1822
1752 Play(); 1823 Play();
(...skipping 251 matching lines...) Expand 10 before | Expand all | Expand 10 after
2004 2075
2005 TEST_F(PipelineIntegrationTest, BasicPlaybackPositiveStartTime) { 2076 TEST_F(PipelineIntegrationTest, BasicPlaybackPositiveStartTime) {
2006 ASSERT_EQ(PIPELINE_OK, Start("nonzero-start-time.webm")); 2077 ASSERT_EQ(PIPELINE_OK, Start("nonzero-start-time.webm"));
2007 Play(); 2078 Play();
2008 ASSERT_TRUE(WaitUntilOnEnded()); 2079 ASSERT_TRUE(WaitUntilOnEnded());
2009 ASSERT_EQ(base::TimeDelta::FromMicroseconds(396000), 2080 ASSERT_EQ(base::TimeDelta::FromMicroseconds(396000),
2010 demuxer_->GetStartTime()); 2081 demuxer_->GetStartTime());
2011 } 2082 }
2012 2083
2013 } // namespace media 2084 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698