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

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: Created 4 years, 9 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_test_base.h" 39 #include "mojo/shell/public/cpp/application_test_base.h"
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after
92 93
93 const char kWebM[] = "video/webm; codecs=\"vp8,vorbis\""; 94 const char kWebM[] = "video/webm; codecs=\"vp8,vorbis\"";
94 const char kWebMVP9[] = "video/webm; codecs=\"vp9\""; 95 const char kWebMVP9[] = "video/webm; codecs=\"vp9\"";
95 const char kAudioOnlyWebM[] = "video/webm; codecs=\"vorbis\""; 96 const char kAudioOnlyWebM[] = "video/webm; codecs=\"vorbis\"";
96 const char kOpusAudioOnlyWebM[] = "video/webm; codecs=\"opus\""; 97 const char kOpusAudioOnlyWebM[] = "video/webm; codecs=\"opus\"";
97 const char kVideoOnlyWebM[] = "video/webm; codecs=\"vp8\""; 98 const char kVideoOnlyWebM[] = "video/webm; codecs=\"vp8\"";
98 #if defined(USE_PROPRIETARY_CODECS) 99 #if defined(USE_PROPRIETARY_CODECS)
99 const char kADTS[] = "audio/aac"; 100 const char kADTS[] = "audio/aac";
100 const char kMP4[] = "video/mp4; codecs=\"avc1.4D4041,mp4a.40.2\""; 101 const char kMP4[] = "video/mp4; codecs=\"avc1.4D4041,mp4a.40.2\"";
101 const char kMP4VideoAVC3[] = "video/mp4; codecs=\"avc3.64001f\""; 102 const char kMP4VideoAVC3[] = "video/mp4; codecs=\"avc3.64001f\"";
103 #if BUILDFLAG(ENABLE_MP4_VP9_DEMUXING)
104 const char kMP4VideoVP9[] = "video/mp4; codecs=\"vp09.00.00.08.01.01.00.00\"";
105 #endif
102 const char kMP4Video[] = "video/mp4; codecs=\"avc1.4D4041\""; 106 const char kMP4Video[] = "video/mp4; codecs=\"avc1.4D4041\"";
103 const char kMP4Audio[] = "audio/mp4; codecs=\"mp4a.40.2\""; 107 const char kMP4Audio[] = "audio/mp4; codecs=\"mp4a.40.2\"";
104 const char kMP3[] = "audio/mpeg"; 108 const char kMP3[] = "audio/mpeg";
105 #endif // defined(USE_PROPRIETARY_CODECS) 109 #endif // defined(USE_PROPRIETARY_CODECS)
106 110
107 // Key used to encrypt test files. 111 // Key used to encrypt test files.
108 const uint8_t kSecretKey[] = {0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b, 112 const uint8_t kSecretKey[] = {0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
109 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c}; 113 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c};
110 114
111 // The key ID for all encrypted files. 115 // The key ID for all encrypted files.
(...skipping 1619 matching lines...) Expand 10 before | Expand all | Expand 10 after
1731 source.EndOfStream(); 1735 source.EndOfStream();
1732 ASSERT_EQ(PIPELINE_OK, pipeline_status_); 1736 ASSERT_EQ(PIPELINE_OK, pipeline_status_);
1733 1737
1734 Play(); 1738 Play();
1735 1739
1736 ASSERT_TRUE(WaitUntilOnEnded()); 1740 ASSERT_TRUE(WaitUntilOnEnded());
1737 source.Shutdown(); 1741 source.Shutdown();
1738 Stop(); 1742 Stop();
1739 } 1743 }
1740 1744
1745 #if BUILDFLAG(ENABLE_MP4_VP9_DEMUXING)
1746 TEST_F(PipelineIntegrationTest, EncryptedPlayback_MP4_VP9_CENC_VideoOnly) {
1747 MockMediaSource source("bear-320x240-v_frag-vp9-cenc.mp4", kMP4VideoVP9,
1748 kAppendWholeFile);
1749 FakeEncryptedMedia encrypted_media(new KeyProvidingApp());
1750 StartPipelineWithEncryptedMedia(&source, &encrypted_media);
1751
1752 source.EndOfStream();
1753 ASSERT_EQ(PIPELINE_OK, pipeline_status_);
1754
1755 Play();
1756
1757 ASSERT_TRUE(WaitUntilOnEnded());
1758 source.Shutdown();
1759 Stop();
1760 }
1761 #endif // #if BUILDFLAG(ENABLE_MP4_VP9_DEMUXING)
1762
1741 TEST_F(PipelineIntegrationTest, BasicPlayback_MediaSource_VideoOnly_MP4_AVC3) { 1763 TEST_F(PipelineIntegrationTest, BasicPlayback_MediaSource_VideoOnly_MP4_AVC3) {
1742 MockMediaSource source("bear-1280x720-v_frag-avc3.mp4", kMP4VideoAVC3, 1764 MockMediaSource source("bear-1280x720-v_frag-avc3.mp4", kMP4VideoAVC3,
1743 kAppendWholeFile); 1765 kAppendWholeFile);
1744 StartPipelineWithMediaSource(&source); 1766 StartPipelineWithMediaSource(&source);
1745 source.EndOfStream(); 1767 source.EndOfStream();
1746 1768
1747 EXPECT_EQ(1u, pipeline_->GetBufferedTimeRanges().size()); 1769 EXPECT_EQ(1u, pipeline_->GetBufferedTimeRanges().size());
1748 EXPECT_EQ(0, pipeline_->GetBufferedTimeRanges().start(0).InMilliseconds()); 1770 EXPECT_EQ(0, pipeline_->GetBufferedTimeRanges().start(0).InMilliseconds());
1749 EXPECT_EQ(k1280IsoAVC3FileDurationMs, 1771 EXPECT_EQ(k1280IsoAVC3FileDurationMs,
1750 pipeline_->GetBufferedTimeRanges().end(0).InMilliseconds()); 1772 pipeline_->GetBufferedTimeRanges().end(0).InMilliseconds());
1751 1773
1752 Play(); 1774 Play();
1753 1775
1754 ASSERT_TRUE(WaitUntilOnEnded()); 1776 ASSERT_TRUE(WaitUntilOnEnded());
1755 source.Shutdown(); 1777 source.Shutdown();
1756 Stop(); 1778 Stop();
1757 } 1779 }
1758 1780
1781 #if BUILDFLAG(ENABLE_MP4_VP9_DEMUXING)
1782 TEST_F(PipelineIntegrationTest, BasicPlayback_MediaSource_VideoOnly_MP4_VP9) {
1783 MockMediaSource source("bear-320x240-v_frag-vp9.mp4", kMP4VideoVP9,
1784 kAppendWholeFile);
1785 StartPipelineWithMediaSource(&source);
1786 source.EndOfStream();
1787 ASSERT_EQ(PIPELINE_OK, pipeline_status_);
1788
1789 Play();
1790
1791 ASSERT_TRUE(WaitUntilOnEnded());
1792 source.Shutdown();
1793 Stop();
1794 }
1795 #endif // #if BUILDFLAG(ENABLE_MP4_VP9_DEMUXING)
1796
1759 #endif // defined(USE_PROPRIETARY_CODECS) 1797 #endif // defined(USE_PROPRIETARY_CODECS)
1760 1798
1761 TEST_F(PipelineIntegrationTest, SeekWhilePaused) { 1799 TEST_F(PipelineIntegrationTest, SeekWhilePaused) {
1762 ASSERT_EQ(PIPELINE_OK, Start("bear-320x240.webm")); 1800 ASSERT_EQ(PIPELINE_OK, Start("bear-320x240.webm"));
1763 1801
1764 base::TimeDelta duration(pipeline_->GetMediaDuration()); 1802 base::TimeDelta duration(pipeline_->GetMediaDuration());
1765 base::TimeDelta start_seek_time(duration / 4); 1803 base::TimeDelta start_seek_time(duration / 4);
1766 base::TimeDelta seek_time(duration * 3 / 4); 1804 base::TimeDelta seek_time(duration * 3 / 4);
1767 1805
1768 Play(); 1806 Play();
(...skipping 251 matching lines...) Expand 10 before | Expand all | Expand 10 after
2020 2058
2021 TEST_F(PipelineIntegrationTest, BasicPlaybackPositiveStartTime) { 2059 TEST_F(PipelineIntegrationTest, BasicPlaybackPositiveStartTime) {
2022 ASSERT_EQ(PIPELINE_OK, Start("nonzero-start-time.webm")); 2060 ASSERT_EQ(PIPELINE_OK, Start("nonzero-start-time.webm"));
2023 Play(); 2061 Play();
2024 ASSERT_TRUE(WaitUntilOnEnded()); 2062 ASSERT_TRUE(WaitUntilOnEnded());
2025 ASSERT_EQ(base::TimeDelta::FromMicroseconds(396000), 2063 ASSERT_EQ(base::TimeDelta::FromMicroseconds(396000),
2026 demuxer_->GetStartTime()); 2064 demuxer_->GetStartTime());
2027 } 2065 }
2028 2066
2029 } // namespace media 2067 } // namespace media
OLDNEW
« media/base/mime_util_internal.cc ('K') | « media/test/data/bear-320x240-v_frag-vp9-cenc.mp4 ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698