Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

<!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);
});
}
});