| Index: third_party/WebKit/LayoutTests/media/video-source-error.html
|
| diff --git a/third_party/WebKit/LayoutTests/media/video-source-error.html b/third_party/WebKit/LayoutTests/media/video-source-error.html
|
| index 8febec3b416a857eecaf0c9b5fc14bf6f045d7c9..46a5a5495012af2cf253c0acf59edce95896f86d 100644
|
| --- a/third_party/WebKit/LayoutTests/media/video-source-error.html
|
| +++ b/third_party/WebKit/LayoutTests/media/video-source-error.html
|
| @@ -1,78 +1,40 @@
|
| -<html lang="en">
|
| - <head>
|
| - <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
| - <title><video> and <source> error test</title>
|
| - <script src=media-file.js></script>
|
| - <!-- TODO(foolip): Convert test to testharness.js. crbug.com/588956
|
| - (Please avoid writing new tests using video-test.js) -->
|
| - <script src=video-test.js></script>
|
| -
|
| - <script>
|
| -
|
| - var sources = [];
|
| -
|
| - function loadeddata()
|
| - {
|
| - consoleWrite("");
|
| - testExpected("relativeURL(video.currentSrc)", findMediaFile("video", "content/test"));
|
| - testExpected("video.error", null);
|
| - consoleWrite("");
|
| - endTest();
|
| - }
|
| -
|
| - function errorEvent(evt)
|
| - {
|
| - var ndx;
|
| - for (ndx = 0; ndx < sources.length; ndx++) {
|
| - if (sources[ndx] == evt.target)
|
| - break;
|
| - }
|
| -
|
| - if (sources[ndx] == evt.target)
|
| - logResult(true, "EVENT(error) from <source id='<em>" + evt.target.id + "</em>' src='<em>" + relativeURL(evt.target.src) + "</em>'>");
|
| - else
|
| - logResult(false, "EVENT(error) from " + evt.target);
|
| -
|
| - testExpected("video.error", null);
|
| - consoleWrite("");
|
| - }
|
| -
|
| - function start()
|
| - {
|
| - findMediaElement();
|
| -
|
| - sources = document.getElementsByTagName('source');
|
| -
|
| - document.addEventListener("error", errorEvent, true);
|
| - waitForEvent("loadstart");
|
| - waitForEvent("waiting");
|
| - waitForEvent("ratechange");
|
| - waitForEvent("durationchange");
|
| - waitForEvent("pause");
|
| - waitForEvent("play");
|
| - waitForEvent("playing");
|
| -
|
| - waitForEvent('loadeddata', loadeddata);
|
| - }
|
| - </script>
|
| - </head>
|
| -
|
| - <body>
|
| -
|
| - <video controls>
|
| - <source id=missing-src type="video/blahblah">
|
| - <source id=bogus-type src=content/test.mp4 type="video/blahblah">
|
| - <source id=missing-file src=content/error2.mpeg type=video/mpeg>
|
| - <source id=format-error src="content/unsupported_track.mov">
|
| - <source id=supported-format-mp4 src=content/test.mp4 type="video/mp4; codecs="avc1.4D400C"">
|
| - <source id=supported-format-ogv src=content/test.ogv type="video/ogg">
|
| - </video>
|
| -
|
| - <p>1. Test that errors fired while evaluating/loading <source> elements are fired at the
|
| - <source> and not at the <video> element.
|
| - <br>2. Verifiy that an 'error' event fired while processing/loading a <source> element
|
| - does not set the media element's 'error' attribute.</p>
|
| -
|
| - <script>start()</script>
|
| - </body>
|
| -</html>
|
| +<!DOCTYPE html>
|
| +<title>Test "error" event are fired on "source" elements and not on "video" while processing invalid "source" elements.</title>
|
| +<script src="../resources/testharness.js"></script>
|
| +<script src="../resources/testharnessreport.js"></script>
|
| +<script src="media-file.js"></script>
|
| +<video>
|
| + <source id="missing-src" type="video/blahblah"></source>
|
| + <source id="bogus-type" src="content/test.mp4" type="video/blahblah"></source>
|
| + <source id="missing-file" src="content/error2.mpeg" type="video/mpeg"></source>
|
| + <source id="format-error" src="content/unsupported_track.mov"></source>
|
| + <source id="supported-format-mp4" src="content/test.mp4" type="video/mp4; codecs="avc1.4D400C""></source>
|
| + <source id="supported-format-ogv" src="content/test.ogv" type="video/ogg"></source>
|
| +</video>
|
| +<script>
|
| +// 1. Test that errors fired while evaluating/loading "source elements are
|
| +// fired at the "source" and not at the "video" element.
|
| +// 2. Verifiy that an "error" event fired while processing/loading a "source" element
|
| +// does not set the media element's "error" attribute.
|
| +async_test(function(t) {
|
| + var video = document.querySelector("video");
|
| +
|
| + document.addEventListener("error", function(event) {
|
| + assert_true(event.target instanceof HTMLSourceElement);
|
| + }, true);
|
| +
|
| + video.onloadstart = t.step_func(function() {});
|
| + video.onwaiting = t.step_func(function() {});
|
| + video.onratechange = t.step_func(function() {});
|
| + video.ondurationchange = t.step_func(function() {});
|
| + video.onpause = t.step_func(function() {});
|
| + video.onplay = t.step_func(function() {});
|
| + video.onplaying = t.step_func(function() {});
|
| + video.onerror = t.unreached_func();
|
| +
|
| + video.onloadeddata = t.step_func_done(function() {
|
| + var url = video.currentSrc;
|
| + assert_equals(url.substr(url.lastIndexOf("/media/") + 7), findMediaFile("video", "content/test"));
|
| + });
|
| +});
|
| +</script>
|
|
|