Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Warnings

<!DOCTYPE html>
<meta charset="utf-8">
<title>Test Background Video Suspend Cancels (Visibility)</title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<script src="manifest.js"></script>
<script src="background_video.js"></script>
<link rel="stylesheet" href="/tests/SimpleTest/test.css"/>
<script type="text/javascript"> "use strict"; var manager = new MediaTestManager; /** * Check that making the element visible before suspend timer delay causes the * the suspend timer to be canceled. * * @param {HTMLMediaElement} video Video element under test. * @returns {Promise} Promise that is resolved when video decode resumes. */ function testSuspendTimerCanceledWhenShown(video) { function ended() { video.removeEventListener("mozcancelvideosuspendtimer", canceled); ok(false, `${video.token} ended before suspend cancels`); this.ended_resolve(); } function canceled() { video.removeEventListener("ended", ended); ok(true, `${video.token} suspend cancels`); this.canceled_resolve(); } let p = Promise.race([ new Promise((resolve) => { video.ended_resolve = resolve; video.addEventListener('ended', ended, { 'once': true }); }), new Promise((resolve) => { video.canceled_resolve = resolve; video.addEventListener('mozcancelvideosuspendtimer', canceled, { 'once': true }); }) ]); Log(video.token, "Set visible"); video.setVisible(true); return p; } startTest({ desc: 'Test Background Video Suspend Cancels (Visibility)', prefs: [ [ "media.test.video-suspend", true ], [ "media.suspend-background-video.enabled", true ], [ "media.suspend-background-video.delay-ms", 10000 ] ], tests: gDecodeSuspendTests, runTest: (test, token) => { let v = appendVideoToDoc(test.name, token); manager.started(token); waitUntilPlaying(v) .then(() => testSuspendTimerStartedWhenHidden(v)) .then(() => testSuspendTimerCanceledWhenShown(v)) .then(() => { ok(true, `${v.token} finished`); manager.finished(token); }); } });