1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 #include "content/browser/media/media_browsertest.h" 6 7 #include "base/strings/stringprintf.h" 8 #include "base/strings/utf_string_conversions.h" 9 #include "content/public/browser/web_contents.h" 10 #include "content/public/common/url_constants.h" 11 #include "content/public/test/browser_test_utils.h" 12 #include "content/shell/browser/shell.h" 13 #include "content/test/content_browser_test_utils.h" 14 15 // TODO(wolenetz): Fix Media.YUV* tests on MSVS 2012 x64. crbug.com/180074 16 #if defined(OS_WIN) && defined(ARCH_CPU_X86_64) && _MSC_VER == 1700 17 #define MAYBE(x) DISABLED_##x 18 #else 19 #define MAYBE(x) x 20 #endif 21 22 namespace content { 23 24 // Common test results. 25 const char MediaBrowserTest::kEnded[] = "ENDED"; 26 const char MediaBrowserTest::kError[] = "ERROR"; 27 const char MediaBrowserTest::kFailed[] = "FAILED"; 28 29 void MediaBrowserTest::SetUp() { 30 // TODO(danakj): The GPU Video Decoder needs real GL bindings. 31 // crbug.com/269087 32 UseRealGLBindings(); 33 34 ContentBrowserTest::SetUp(); 35 } 36 37 void MediaBrowserTest::RunMediaTestPage( 38 const char* html_page, std::vector<StringPair>* query_params, 39 const char* expected, bool http) { 40 GURL gurl; 41 std::string query = ""; 42 if (query_params != NULL && !query_params->empty()) { 43 std::vector<StringPair>::const_iterator itr = query_params->begin(); 44 query = base::StringPrintf("%s=%s", itr->first, itr->second); 45 ++itr; 46 for (; itr != query_params->end(); ++itr) { 47 query.append(base::StringPrintf("&%s=%s", itr->first, itr->second)); 48 } 49 } 50 if (http) { 51 ASSERT_TRUE(test_server()->Start()); 52 gurl = test_server()->GetURL( 53 base::StringPrintf("files/media/%s?%s", html_page, query.c_str())); 54 } else { 55 base::FilePath test_file_path = GetTestFilePath("media", html_page); 56 gurl = GetFileUrlWithQuery(test_file_path, query); 57 } 58 RunTest(gurl, expected); 59 } 60 61 void MediaBrowserTest::RunTest(const GURL& gurl, const char* expected) { 62 const base::string16 expected_title = ASCIIToUTF16(expected); 63 DVLOG(1) << "Running test URL: " << gurl; 64 TitleWatcher title_watcher(shell()->web_contents(), expected_title); 65 AddWaitForTitles(&title_watcher); 66 NavigateToURL(shell(), gurl); 67 68 base::string16 final_title = title_watcher.WaitAndGetTitle(); 69 EXPECT_EQ(expected_title, final_title); 70 } 71 72 void MediaBrowserTest::AddWaitForTitles(content::TitleWatcher* title_watcher) { 73 title_watcher->AlsoWaitForTitle(ASCIIToUTF16(kEnded)); 74 title_watcher->AlsoWaitForTitle(ASCIIToUTF16(kError)); 75 title_watcher->AlsoWaitForTitle(ASCIIToUTF16(kFailed)); 76 } 77 78 // Tests playback and seeking of an audio or video file over file or http based 79 // on a test parameter. Test starts with playback, then, after X seconds or the 80 // ended event fires, seeks near end of file; see player.html for details. The 81 // test completes when either the last 'ended' or an 'error' event fires. 82 class MediaTest : public testing::WithParamInterface<bool>, 83 public MediaBrowserTest { 84 public: 85 // Play specified audio over http:// or file:// depending on |http| setting. 86 void PlayAudio(const char* media_file, bool http) { 87 PlayMedia("audio", media_file, http); 88 } 89 90 // Play specified video over http:// or file:// depending on |http| setting. 91 void PlayVideo(const char* media_file, bool http) { 92 PlayMedia("video", media_file, http); 93 } 94 95 // Run specified color format test with the expected result. 96 void RunColorFormatTest(const char* media_file, const char* expected) { 97 base::FilePath test_file_path = GetTestFilePath("media", "blackwhite.html"); 98 RunTest(GetFileUrlWithQuery(test_file_path, media_file), expected); 99 } 100 101 void PlayMedia(const char* tag, const char* media_file, bool http) { 102 std::vector<StringPair> query_params; 103 query_params.push_back(std::make_pair(tag, media_file)); 104 RunMediaTestPage("player.html", &query_params, kEnded, http); 105 } 106 }; 107 108 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearTheora) { 109 PlayVideo("bear.ogv", GetParam()); 110 } 111 112 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearSilentTheora) { 113 PlayVideo("bear_silent.ogv", GetParam()); 114 } 115 116 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearWebm) { 117 PlayVideo("bear.webm", GetParam()); 118 } 119 120 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearSilentWebm) { 121 PlayVideo("bear_silent.webm", GetParam()); 122 } 123 124 #if defined(USE_PROPRIETARY_CODECS) 125 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearMp4) { 126 PlayVideo("bear.mp4", GetParam()); 127 } 128 129 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearSilentMp4) { 130 PlayVideo("bear_silent.mp4", GetParam()); 131 } 132 133 // While we support the big endian (be) PCM codecs on Chromium, Quicktime seems 134 // to be the only creator of this format and only for .mov files. 135 // TODO(dalecurtis/ihf): Find or create some .wav test cases for "be" format. 136 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearMovPcmS16be) { 137 PlayVideo("bear_pcm_s16be.mov", GetParam()); 138 } 139 140 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearMovPcmS24be) { 141 PlayVideo("bear_pcm_s24be.mov", GetParam()); 142 } 143 #endif 144 145 #if defined(OS_CHROMEOS) 146 #if defined(USE_PROPRIETARY_CODECS) 147 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearAviMp3Mpeg4) { 148 PlayVideo("bear_mpeg4_mp3.avi", GetParam()); 149 } 150 151 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearAviMp3Mpeg4Asp) { 152 PlayVideo("bear_mpeg4asp_mp3.avi", GetParam()); 153 } 154 155 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearAviMp3Divx) { 156 PlayVideo("bear_divx_mp3.avi", GetParam()); 157 } 158 159 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBear3gpAacH264) { 160 PlayVideo("bear_h264_aac.3gp", GetParam()); 161 } 162 163 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBear3gpAmrnbMpeg4) { 164 PlayVideo("bear_mpeg4_amrnb.3gp", GetParam()); 165 } 166 167 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearWavGsmms) { 168 PlayAudio("bear_gsm_ms.wav", GetParam()); 169 } 170 171 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearFlac) { 172 PlayAudio("bear.flac", GetParam()); 173 } 174 #endif 175 #endif 176 177 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearWavAlaw) { 178 PlayAudio("bear_alaw.wav", GetParam()); 179 } 180 181 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearWavMulaw) { 182 PlayAudio("bear_mulaw.wav", GetParam()); 183 } 184 185 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearWavPcm) { 186 PlayAudio("bear_pcm.wav", GetParam()); 187 } 188 189 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearWavPcm3kHz) { 190 PlayAudio("bear_3kHz.wav", GetParam()); 191 } 192 193 IN_PROC_BROWSER_TEST_P(MediaTest, VideoBearWavPcm192kHz) { 194 PlayAudio("bear_192kHz.wav", GetParam()); 195 } 196 197 IN_PROC_BROWSER_TEST_P(MediaTest, VideoTulipWebm) { 198 PlayVideo("tulip2.webm", GetParam()); 199 } 200 201 // Covers tear-down when navigating away as opposed to browser exiting. 202 IN_PROC_BROWSER_TEST_F(MediaTest, Navigate) { 203 PlayVideo("bear.ogv", false); 204 NavigateToURL(shell(), GURL(kAboutBlankURL)); 205 EXPECT_FALSE(shell()->web_contents()->IsCrashed()); 206 } 207 208 INSTANTIATE_TEST_CASE_P(File, MediaTest, ::testing::Values(false)); 209 INSTANTIATE_TEST_CASE_P(Http, MediaTest, ::testing::Values(true)); 210 211 IN_PROC_BROWSER_TEST_F(MediaTest, MAYBE(Yuv420pTheora)) { 212 RunColorFormatTest("yuv420p.ogv", "ENDED"); 213 } 214 215 IN_PROC_BROWSER_TEST_F(MediaTest, MAYBE(Yuv422pTheora)) { 216 RunColorFormatTest("yuv422p.ogv", "ENDED"); 217 } 218 219 IN_PROC_BROWSER_TEST_F(MediaTest, MAYBE(Yuv444pTheora)) { 220 // TODO(scherkus): Support YUV444 http://crbug.com/104711 221 RunColorFormatTest("yuv424p.ogv", "ERROR"); 222 } 223 224 IN_PROC_BROWSER_TEST_F(MediaTest, MAYBE(Yuv420pVp8)) { 225 RunColorFormatTest("yuv420p.webm", "ENDED"); 226 } 227 228 #if defined(USE_PROPRIETARY_CODECS) 229 IN_PROC_BROWSER_TEST_F(MediaTest, MAYBE(Yuv420pH264)) { 230 RunColorFormatTest("yuv420p.mp4", "ENDED"); 231 } 232 233 IN_PROC_BROWSER_TEST_F(MediaTest, MAYBE(Yuvj420pH264)) { 234 // TODO(rileya): Support YUVJ420P properly http://crbug.com/310273 235 RunColorFormatTest("yuvj420p.mp4", "FAILED"); 236 } 237 238 IN_PROC_BROWSER_TEST_F(MediaTest, MAYBE(Yuv422pH264)) { 239 RunColorFormatTest("yuv422p.mp4", "ENDED"); 240 } 241 242 IN_PROC_BROWSER_TEST_F(MediaTest, MAYBE(Yuv444pH264)) { 243 // TODO(scherkus): Support YUV444 http://crbug.com/104711 244 RunColorFormatTest("yuv444p.mp4", "ERROR"); 245 } 246 247 #if defined(OS_CHROMEOS) 248 IN_PROC_BROWSER_TEST_F(MediaTest, Yuv420pMpeg4) { 249 RunColorFormatTest("yuv420p.avi", "ENDED"); 250 } 251 #endif // defined(OS_CHROMEOS) 252 #endif // defined(USE_PROPRIETARY_CODECS) 253 254 } // namespace content 255