mirror of
https://github.com/classilla/tenfourfox.git
synced 2025-01-08 07:31:32 +00:00
73 lines
3.6 KiB
HTML
73 lines
3.6 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<title>Test MediaSource behavior when receiving multiple seek requests during a pending seek.</title>
|
|
<meta name="timeout" content="long">
|
|
<script src="/resources/testharness.js"></script>
|
|
<script src="/resources/testharnessreport.js"></script>
|
|
<script src="mediasource-util.js"></script>
|
|
</head>
|
|
<body>
|
|
<div id="log"></div>
|
|
<script>
|
|
|
|
mediasource_testafterdataloaded(function(test, mediaElement, mediaSource, segmentInfo, sourceBuffer, mediaData)
|
|
{
|
|
mediaElement.play();
|
|
|
|
// Append all media data for complete playback.
|
|
test.expectEvent(sourceBuffer, 'updateend', 'sourceBuffer end update.');
|
|
test.expectEvent(mediaElement, 'loadedmetadata', 'Reached HAVE_METADATA');
|
|
test.expectEvent(mediaElement, 'playing', 'Playing media.');
|
|
sourceBuffer.appendBuffer(mediaData);
|
|
|
|
test.waitForExpectedEvents(function()
|
|
{
|
|
var bufferedRanges = mediaElement.buffered;
|
|
|
|
assert_greater_than_equal(mediaElement.duration, 4.0, 'Duration is >= 4.0s');
|
|
assert_equals(bufferedRanges.length, 1, 'Just one buffered range');
|
|
assert_less_than_equal(bufferedRanges.start(0), 1.0, 'Buffered range starts <= 1.0s');
|
|
assert_greater_than_equal(bufferedRanges.end(0), 4.0, 'Buffered range ends >= 4.0s');
|
|
|
|
test.expectEvent(mediaElement, 'seeking', 'seeking');
|
|
test.expectEvent(mediaElement, 'timeupdate', 'timeupdate');
|
|
test.expectEvent(mediaElement, 'seeked', 'seeked');
|
|
|
|
// Request seeks.
|
|
mediaElement.currentTime = 1.0;
|
|
|
|
// This 'ephemeral' seek should be invisible to javascript, except any latency incurred in its processing.
|
|
mediaElement.currentTime = 3.0;
|
|
|
|
mediaElement.currentTime = 1.0;
|
|
|
|
assert_true(mediaElement.seeking, 'Element is seeking');
|
|
assert_equals(mediaElement.currentTime, 1.0, 'Element time is at last seek time');
|
|
});
|
|
|
|
test.waitForExpectedEvents(function()
|
|
{
|
|
// No more seeking or seeked events should occur.
|
|
mediaElement.addEventListener('seeking', test.unreached_func("Unexpected event 'seeking'"));
|
|
mediaElement.addEventListener('seeked', test.unreached_func("Unexpected event 'seeked'"));
|
|
|
|
assert_false(mediaElement.seeking, 'Element is not seeking');
|
|
assert_greater_than_equal(mediaElement.currentTime, 1.0, 'Element time is at or after last seek time');
|
|
assert_less_than(mediaElement.currentTime, 3.0, 'Element time is before the ephemeral seek time');
|
|
|
|
var timeBeforeWait = mediaElement.currentTime;
|
|
test.waitForCurrentTimeChange(mediaElement, function()
|
|
{
|
|
// Time should have advanced a little, but not yet reached the ephemeral seek time.
|
|
assert_greater_than(mediaElement.currentTime, timeBeforeWait, 'Element time has increased');
|
|
assert_less_than(mediaElement.currentTime, 3.0, 'Element time is still before the ephemeral seek time');
|
|
test.done();
|
|
});
|
|
});
|
|
}, 'Test redundant fully prebuffered seek');
|
|
|
|
</script>
|
|
</body>
|
|
</html>
|