зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1394702 - rewrite test_seek_out_of_range.html to be more robust. r=kaku
See comment 20 for the root cause. We wait for both 'seeked' and 'ended' events to fire to make sure playback has reached the end before calling play(). MozReview-Commit-ID: 55NEmqyDuSI --HG-- extra : rebase_source : 3e1eda99e7fee247ea18c4fd4420f00338710b09
This commit is contained in:
Родитель
0c8e8db29e
Коммит
f80989079d
|
@ -18,43 +18,7 @@ var manager = new MediaTestManager;
|
||||||
|
|
||||||
// Test if the ended event works correctly.
|
// Test if the ended event works correctly.
|
||||||
|
|
||||||
function startTest(e) {
|
async function initTest(test, token) {
|
||||||
var v = e.target;
|
|
||||||
checkMetadata(v._name, v, v._test);
|
|
||||||
is(v._loadedMetadata, false, "Should only receive one loadedmetadata event for " + v._name);
|
|
||||||
v._loadedMetadata = true;
|
|
||||||
v.currentTime = 3.0 * v.duration;
|
|
||||||
}
|
|
||||||
|
|
||||||
function playbackEnded(e) {
|
|
||||||
var v = e.target;
|
|
||||||
// We should have dispatched an ended event when we seeked to the end of
|
|
||||||
// media, but we want the ended event which dispatches once playback has
|
|
||||||
// completed after the seek to the beginning.
|
|
||||||
if (!v._played)
|
|
||||||
return;
|
|
||||||
ok(v.ended, "Checking ended set after seeking to EOF and playing for " + v._name);
|
|
||||||
ok(!v._finished, "Should only hit the end once for " + v._name);
|
|
||||||
v._finished = true;
|
|
||||||
removeNodeAndSource(v);
|
|
||||||
manager.finished(v.token);
|
|
||||||
}
|
|
||||||
|
|
||||||
function endSeek(e) {
|
|
||||||
var v = e.target;
|
|
||||||
if (v._seeked)
|
|
||||||
return;
|
|
||||||
v._seeked = true;
|
|
||||||
ok(Math.abs(v.duration - v.currentTime) < 0.1,
|
|
||||||
"Should be at end of media for " + v._name + " t=" + v.currentTime + " d=" + v.duration);
|
|
||||||
v.play();
|
|
||||||
}
|
|
||||||
|
|
||||||
function playing(e) {
|
|
||||||
e.target._played = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function initTest(test, token) {
|
|
||||||
var type = getMajorMimeType(test.type);
|
var type = getMajorMimeType(test.type);
|
||||||
var v = document.createElement(type);
|
var v = document.createElement(type);
|
||||||
v.preload = "auto";
|
v.preload = "auto";
|
||||||
|
@ -62,16 +26,22 @@ function initTest(test, token) {
|
||||||
manager.started(token);
|
manager.started(token);
|
||||||
v.src = test.name;
|
v.src = test.name;
|
||||||
v._name = test.name;
|
v._name = test.name;
|
||||||
v._finished = false;
|
|
||||||
v._test = test;
|
|
||||||
v._loadedMetadata = false;
|
|
||||||
v._seeked = false;
|
|
||||||
v._played = false;
|
|
||||||
v.addEventListener("loadedmetadata", startTest);
|
|
||||||
v.addEventListener("playing", playing);
|
|
||||||
v.addEventListener("seeked", endSeek);
|
|
||||||
v.addEventListener("ended", playbackEnded);
|
|
||||||
document.body.appendChild(v);
|
document.body.appendChild(v);
|
||||||
|
|
||||||
|
await once(v, "loadedmetadata");
|
||||||
|
info(`${v._name}: seeking to the end of the media.`);
|
||||||
|
v.currentTime = 3.0 * v.duration;
|
||||||
|
// Wait for 'seeked' and 'ended' to be fired.
|
||||||
|
await Promise.all([once(v, "seeked"), once(v, "ended")]);
|
||||||
|
// Check currentTime is near the end of the media.
|
||||||
|
ok(Math.abs(v.duration - v.currentTime) < 0.1,
|
||||||
|
"Should be at end of media for " + v._name + " t=" + v.currentTime + " d=" + v.duration);
|
||||||
|
// Call play() to start playback from the beginning.
|
||||||
|
v.play();
|
||||||
|
await once(v, "ended");
|
||||||
|
ok(v.ended, "Checking ended set after seeking to EOF and playing for " + v._name);
|
||||||
|
removeNodeAndSource(v);
|
||||||
|
manager.finished(v.token);
|
||||||
}
|
}
|
||||||
|
|
||||||
manager.runTests(gSmallTests, initTest);
|
manager.runTests(gSmallTests, initTest);
|
||||||
|
|
Загрузка…
Ссылка в новой задаче