mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 707777 - Rewrite test_bug493187.html to check readyState >= HAVE_FUTURE_DATA after seeking. r=roc
This commit is contained in:
parent
bdb778d2f4
commit
988a05aa88
@ -15,67 +15,79 @@ https://bugzilla.mozilla.org/show_bug.cgi?id=493187
|
|||||||
<pre id="test">
|
<pre id="test">
|
||||||
<script class="testbody" type="text/javascript">
|
<script class="testbody" type="text/javascript">
|
||||||
|
|
||||||
SimpleTest.expectAssertions(0, 2);
|
// Decrease parallelism for this test requires decent decoding performance in
|
||||||
|
// order to pass the test.
|
||||||
|
PARALLEL_TESTS = 1;
|
||||||
|
|
||||||
var manager = new MediaTestManager;
|
var manager = new MediaTestManager;
|
||||||
|
|
||||||
function start(e) {
|
function finish(v) {
|
||||||
var v = e.target;
|
v.onerror = null;
|
||||||
info("[" + v._name + "] start");
|
removeNodeAndSource(v);
|
||||||
e.target.currentTime = e.target.duration / 4;
|
manager.finished(v.token);
|
||||||
}
|
}
|
||||||
|
|
||||||
function startSeeking(e) {
|
function timeupdate(e) {
|
||||||
var v = e.target;
|
var v = e.target;
|
||||||
info("[" + v._name + "] seeking");
|
var b = v.buffered;
|
||||||
e.target._seeked = true;
|
var start = b.start(0);
|
||||||
}
|
var end = b.end(0);
|
||||||
|
// We got enough data buffered, try to seek within the buffered range.
|
||||||
function canPlayThrough(e) {
|
if (end - start >= v.duration / 2) {
|
||||||
var v = e.target;
|
info("[" + v._name + "] buffered start=" + start + " end=" + end);
|
||||||
info("[" + v._name + "] canPlayThrough");
|
v.ontimeupdate = null;
|
||||||
if (v._seeked && !v._finished) {
|
// Seek to the middle of the buffered range.
|
||||||
ok(true, "[" + v._name + "] got canplaythrough after seek");
|
var t = (start + end) / 2;
|
||||||
v._finished = true;
|
info("[" + v._name + "] seeking to " + t);
|
||||||
v.parentNode.removeChild(v);
|
v.currentTime = t;
|
||||||
v.src = "";
|
|
||||||
manager.finished(v.token);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function seeked(e) {
|
function seeked(e) {
|
||||||
var v = e.target;
|
var v = e.target;
|
||||||
info("[" + v._name + "] seeked");
|
info("[" + v._name + "] seeked currentTime=" + v.currentTime + " readyState=" + v.readyState);
|
||||||
|
// Having seeked within the buffered range, readyState should be at least
|
||||||
|
// HAVE_FUTURE_DATA now or later (buffered data becoming decoded data).
|
||||||
|
if (v.readyState >= v.HAVE_FUTURE_DATA) {
|
||||||
|
finish(v);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
v.oncanplay = function() {
|
||||||
|
info("[" + v._name + "] oncanplay currentTime=" + v.currentTime + " readyState=" + v.readyState);
|
||||||
|
// Pass the test when we receive "oncanplay". Don't check |readyState >= HAVE_FUTURE_DATA|
|
||||||
|
// for "oncanplay" is dispatched asynchronously, readyState could be changed
|
||||||
|
// before "oncanplay" is received.
|
||||||
|
v.oncanplay = null;
|
||||||
|
v.onended = null;
|
||||||
|
finish(v);
|
||||||
|
}
|
||||||
|
v.onended = function() {
|
||||||
|
v.oncanplay = null;
|
||||||
|
v.onended = null;
|
||||||
|
ok(false, "[" + v._name + "] readyState=" + v.readyState + " not reaching HAVE_FUTURE_DATA before ended");
|
||||||
|
finish(v);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function error(e) {
|
function error(e) {
|
||||||
var v = e.target;
|
var v = e.target;
|
||||||
info("[" + v._name + "] error");
|
info("[" + v._name + "] error=" + v.error.code);
|
||||||
|
finish(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
function startTest(test, token) {
|
function startTest(test, token) {
|
||||||
// TODO: Bug 568402, there's a bug in the WAV backend where we sometimes
|
|
||||||
// don't send canplaythrough events after seeking. Once that is fixed,
|
|
||||||
// we should remove this guard below so that we run this test for audio.
|
|
||||||
var type = getMajorMimeType(test.type);
|
|
||||||
if (type != "video")
|
|
||||||
return;
|
|
||||||
|
|
||||||
var v = document.createElement('video');
|
var v = document.createElement('video');
|
||||||
v.token = token;
|
v.token = token;
|
||||||
manager.started(token);
|
manager.started(token);
|
||||||
|
|
||||||
v.src = test.name;
|
v.src = test.name;
|
||||||
v._name = test.name;
|
v._name = test.name;
|
||||||
v._seeked = false;
|
v.ontimeupdate = timeupdate;
|
||||||
v._finished = false;
|
v.onseeked = seeked;
|
||||||
v.preload = "auto";
|
v.onerror = error;
|
||||||
v.addEventListener("loadedmetadata", start, false);
|
|
||||||
v.addEventListener("canplaythrough", canPlayThrough, false);
|
|
||||||
v.addEventListener("seeking", startSeeking, false);
|
|
||||||
v.addEventListener("seeked", seeked, false);
|
|
||||||
v.addEventListener("error", error, false);
|
|
||||||
document.body.appendChild(v);
|
document.body.appendChild(v);
|
||||||
|
v.play();
|
||||||
}
|
}
|
||||||
|
|
||||||
SimpleTest.waitForExplicitFinish();
|
SimpleTest.waitForExplicitFinish();
|
||||||
|
Loading…
Reference in New Issue
Block a user