2009-05-17 19:00:44 -07:00
|
|
|
<!DOCTYPE HTML>
|
|
|
|
<html>
|
|
|
|
<!--
|
|
|
|
https://bugzilla.mozilla.org/show_bug.cgi?id=479863
|
|
|
|
-->
|
|
|
|
<head>
|
|
|
|
<title>Test for Bug 479863</title>
|
|
|
|
<script type="application/javascript" src="/MochiKit/packed.js"></script>
|
|
|
|
<script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
|
|
|
|
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
|
|
|
|
<script type="application/javascript" src="use_large_cache.js"></script>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=479863">Mozilla Bug 479863</a>
|
|
|
|
<p id="display"></p>
|
|
|
|
<div id="content" style="display: none">
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
2009-05-17 19:03:37 -07:00
|
|
|
<video id='v1' onerror="event.stopPropagation()"></video>
|
|
|
|
<video id='v2' onerror="event.stopPropagation()" autobuffer></video>
|
|
|
|
<video id='v3' onerror="event.stopPropagation()" autoplay></video>
|
|
|
|
<video id='v4' onerror="event.stopPropagation()"></video>
|
|
|
|
<video id='v5' onerror="event.stopPropagation()"></video>
|
|
|
|
<video id='v6' onerror="event.stopPropagation()"></video>
|
|
|
|
|
|
|
|
<pre id="test">
|
2009-05-17 19:00:44 -07:00
|
|
|
<script type="application/javascript">
|
2009-05-17 19:03:37 -07:00
|
|
|
var suspends = {};
|
|
|
|
var loads = {};
|
2009-05-17 19:00:44 -07:00
|
|
|
var totalLoadEvents = 0;
|
|
|
|
var expectedLoadEvents = 6;
|
|
|
|
|
|
|
|
function loaded(event) {
|
|
|
|
loads[event.target.id] = true;
|
2009-05-18 21:10:08 -07:00
|
|
|
ok(true, "Loaded " + event.target.id);
|
2009-05-17 19:00:44 -07:00
|
|
|
++totalLoadEvents;
|
|
|
|
if (totalLoadEvents == expectedLoadEvents) {
|
2009-05-18 21:10:08 -07:00
|
|
|
ok(suspends.v1, "v1 should have suspended");
|
|
|
|
ok(!suspends.v2, "v2 should not have suspended");
|
|
|
|
ok(!suspends.v3, "v3 should not have suspended");
|
|
|
|
ok(suspends.v4, "v4 should have suspended");
|
|
|
|
ok(suspends.v5, "v5 should have suspended");
|
|
|
|
ok(suspends.v6, "v6 should have suspended");
|
2009-05-17 19:00:44 -07:00
|
|
|
SimpleTest.finish();
|
|
|
|
}
|
|
|
|
}
|
2009-05-17 19:03:37 -07:00
|
|
|
|
|
|
|
function suspended(event) {
|
2009-05-18 16:06:10 -07:00
|
|
|
// If the element suspends the download, it should not then be able to
|
|
|
|
// complete it, so we should be stuck in NETWORK_IDLE even though this
|
|
|
|
// even though this event handler could run a long time after the actual
|
|
|
|
// suspend.
|
|
|
|
is(event.target.networkState, event.target.NETWORK_IDLE,
|
|
|
|
event.target.id + " suspended networkState");
|
2009-05-17 19:03:37 -07:00
|
|
|
suspends[event.target.id] = true;
|
2009-05-17 19:00:44 -07:00
|
|
|
if (event.target.id == "v1") {
|
|
|
|
event.target.autobuffer = true;
|
|
|
|
} else if (event.target.id == "v4") {
|
|
|
|
event.target.play();
|
|
|
|
} else if (event.target.id == "v5") {
|
|
|
|
event.target.currentTime = 0.1;
|
|
|
|
} else if (event.target.id == "v6") {
|
|
|
|
event.target.autoplay = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-05-17 19:03:37 -07:00
|
|
|
function logEvent(event) {
|
|
|
|
dump(event.type + " " + event.target.id + "\n");
|
|
|
|
}
|
2009-05-17 19:00:44 -07:00
|
|
|
|
2009-05-17 19:03:37 -07:00
|
|
|
var key = Math.random();
|
|
|
|
var eventList = ["metadataloaded", "loadeddata", "playing", "load", "stalled", "suspend", "ended"];
|
|
|
|
for (var i = 1; i <= expectedLoadEvents; ++i) {
|
|
|
|
var id = "v" + i;
|
|
|
|
suspends[id] = loads[id] = false;
|
|
|
|
var v = document.getElementById(id);
|
|
|
|
v.addEventListener("suspend", suspended, false);
|
|
|
|
v.addEventListener("load", loaded, false);
|
|
|
|
for (var n = 0; n < eventList.length; ++n) {
|
|
|
|
v.addEventListener(eventList[n], logEvent, false);
|
|
|
|
}
|
|
|
|
v.src = "seek.ogv?key=" + key + "&id=" + id;
|
|
|
|
}
|
2009-05-17 19:00:44 -07:00
|
|
|
SimpleTest.waitForExplicitFinish();
|
|
|
|
</script>
|
|
|
|
</pre>
|
|
|
|
</body>
|
|
|
|
</html>
|