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

Unified Diff: third_party/WebKit/LayoutTests/media/media-element-play-after-eos.html

Issue 2031783002: Convert media-cont* and media-element* tests to testharness.js (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address comments Created 4 years, 7 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 side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/LayoutTests/media/media-element-play-after-eos.html
diff --git a/third_party/WebKit/LayoutTests/media/media-element-play-after-eos.html b/third_party/WebKit/LayoutTests/media/media-element-play-after-eos.html
index 91c52fd63906d5fe66750c64417d61151932ab67..dcc55461eb1242339a1ed0e8ccf3327c69628b53 100644
--- a/third_party/WebKit/LayoutTests/media/media-element-play-after-eos.html
+++ b/third_party/WebKit/LayoutTests/media/media-element-play-after-eos.html
@@ -1,55 +1,43 @@
<!DOCTYPE html>
-<html>
- <head>
- <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 repeated = false;
- var mediaElement = new Audio();
-
- function start()
- {
- mediaElement.src = findMediaFile('audio', 'content/silence');
- waitForEvent("loadedmetadata", mediaLoadedMetadata);
+<title>This test ensures that media element fires the "playing" event every time it starts playing after eos. It also ensure that "pause" and "ended" events are fired when media playback ends.</title>
+<script src="../resources/testharness.js"></script>
+<script src="../resources/testharnessreport.js"></script>
+<script src="media-file.js"></script>
+<audio></audio>
+<script>
+// TODO(srirama.m): Modify the test to record events and check for order
+// at the end of test. See autoplay-with-preload-none.html for help.
+async_test(function(t) {
+ var loop = true;
+ var audio = document.querySelector("audio");
+ audio.src = findMediaFile("audio", "content/silence");
+
+ audio.onloadedmetadata = t.step_func(function() {
+ audio.onplaying = t.step_func(mediaPlaying);
+
+ audio.onpause = t.step_func(function() {
+ assert_true(audio.paused);
+ });
+
+ audio.onended = t.step_func(function() {
+ assert_true(audio.ended, true);
+
+ if (!loop) {
+ t.done();
+ return;
}
- function mediaLoadedMetadata()
- {
- waitForEventOnce("playing", mediaPlaying);
- waitForEvent("pause", mediaPause);
- waitForEvent("ended", mediaEnded);
- run("mediaElement.play()");
- }
+ loop = false;
+ audio.onplaying = t.step_func(mediaPlaying);
+ audio.play();
+ });
- function mediaPlaying()
- {
- mediaElement.currentTime = mediaElement.duration - 0.2;
- }
-
- function mediaPause()
- {
- testExpected("mediaElement.paused", true);
- }
-
- function mediaEnded()
- {
- testExpected("mediaElement.ended", true);
-
- if (repeated) {
- endTest();
- return;
- }
-
- repeated = true;
- waitForEventOnce("playing", mediaPlaying);
- run("mediaElement.play()");
- }
+ audio.play();
+ });
- </script>
- </head>
- <body onload="start()">
- <p>This tests ensure that media element emits the 'playing' event every time it starts playing after eos. It also ensure that 'pause' and 'ended' events are sent when media playback ends.</p>
- </body>
-</html>
+ function mediaPlaying() {
+ audio.onplaying = null;
+ audio.currentTime = audio.duration - 0.2;
+ }
+});
+</script>

Powered by Google App Engine
This is Rietveld 408576698