summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/media-source/mediasource-seekable.html
blob: c379a63ba169532f692304bc659c53f7edbf61c2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
<!DOCTYPE html>
<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
<meta charset="utf-8">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="mediasource-util.js"></script>
<script>
    mediasource_test(function(test, mediaElement, mediaSource)
    {
        mediaElement.addEventListener('error', test.unreached_func("Unexpected event 'error'"));
        mediaElement.addEventListener('ended', test.step_func_done(function () {}));

        var sourceBuffer = mediaSource.addSourceBuffer(MediaSourceUtil.AUDIO_ONLY_TYPE);

        assertSeekableEquals(mediaElement, '{ }', 'mediaElement.seekable');
        test.done();
    }, 'Get seekable time ranges when the sourcebuffer is empty.');

    mediasource_testafterdataloaded(function(test, mediaElement, mediaSource, segmentInfo, sourceBuffer, mediaData)
    {
        var initSegment = MediaSourceUtil.extractSegmentData(mediaData, segmentInfo.init);
        test.expectEvent(mediaElement, 'durationchange', 'mediaElement got duration');
        sourceBuffer.appendBuffer(initSegment);
        test.waitForExpectedEvents(function()
        {
            assert_equals(mediaElement.duration, segmentInfo.duration);
            assertSeekableEquals(mediaElement, '{ [0.000, ' + segmentInfo.duration.toFixed(3) + ') }', 'mediaElement.seekable');
            test.done();
        });
    }, 'Get seekable time ranges after init segment received.');

    mediasource_testafterdataloaded(function(test, mediaElement, mediaSource, segmentInfo, sourceBuffer, mediaData)
    {
        var initSegment = MediaSourceUtil.extractSegmentData(mediaData, segmentInfo.init);
        test.expectEvent(mediaElement, 'durationchange', 'mediaElement got duration after initsegment');
        sourceBuffer.appendBuffer(initSegment);
        test.waitForExpectedEvents(function()
        {
            test.expectEvent(mediaElement, 'durationchange', 'mediaElement got infinity duration');
            mediaSource.duration = Infinity;
            test.waitForExpectedEvents(function()
            {
                assertSeekableEquals(mediaElement, '{ }', 'mediaElement.seekable');

                // Append a segment from the middle of the stream to make sure that seekable does not use buffered.start(0) or duration as first or last value
                var midSegment = MediaSourceUtil.extractSegmentData(mediaData, segmentInfo.media[2]);
                test.expectEvent(sourceBuffer, 'update');
                test.expectEvent(sourceBuffer, 'updateend');
                sourceBuffer.appendBuffer(midSegment);
                test.waitForExpectedEvents(function()
                {
                    assert_equals(mediaElement.seekable.length, 1, 'mediaElement.seekable.length');
                    assert_equals(mediaElement.buffered.length, 1, 'mediaElement.buffered.length');
                    assert_not_equals(mediaElement.seekable.start(0), mediaElement.buffered.start(0));
                    assert_equals(mediaElement.seekable.start(0), 0);
                    assert_not_equals(mediaElement.seekable.end(0), mediaElement.duration);
                    assert_not_equals(mediaElement.seekable.end(0), mediaElement.buffered.start(0));
                    assert_equals(mediaElement.seekable.end(0), mediaElement.buffered.end(0));
                    test.done();
                });
            });
        });
    }, 'Get seekable time ranges on an infinite stream.');
</script>