summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/media-source/SourceBuffer-abort-updating.html
blob: 1132d14663e2c83e520db6720aafbf135f897fb0 (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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
<!doctype html>
<html>
<head>
  <meta charset='utf-8'>
  <title>Check SourceBuffer#abort() when the updating attribute is true</title>
  <script src="/resources/testharness.js"></script>
  <script src="/resources/testharnessreport.js"></script>
</head>
<body>
<div id="log"></div>

<script>
var contents = {'/media/white.webm': 'video/webm; codecs="vorbis,vp8"',
                '/media/white.mp4' : 'video/mp4'};

function GET(url, processBody) {
    var xhr = new XMLHttpRequest();
    xhr.open('GET', url, true);
    xhr.responseType = 'arraybuffer';
    xhr.send();
    xhr.onload = function(e) {
        if (xhr.status != 200) {
            alert("Unexpected status code " + xhr.status + " for " + url);
            return false;
        }
        processBody(new Uint8Array(xhr.response));
    };
}
//check the browser supports the MIME used in this test
function isTypeSupported(mime) {
    if(!MediaSource.isTypeSupported(mime)) {
        this.step(function() {
            assert_unreached("Browser doesn't support the MIME used in this test: " + mime);
        });
        this.done();
        return false;
    }
    return true;
}
function mediaTest(file, mime) {
    async_test(function(t) {
        if(!isTypeSupported.bind(t)(mime)) {
            return;
        }
        GET(file, function(data) {
            var mediaSource = new MediaSource();
            var num_updateend = 0;
            var events = [];
            mediaSource.addEventListener('sourceopen', t.step_func(function(e) {
                var sourceBuffer = mediaSource.addSourceBuffer(mime);
                assert_equals(sourceBuffer.updating, false);
                sourceBuffer.addEventListener('updatestart', t.step_func(function(e) {
                    events.push('updatestart');
                    //abort when sourceBuffer#updating is true
                    sourceBuffer.abort();

                    assert_equals(sourceBuffer.updating, false,
                                  'Check updating value after calling abort.');
                    assert_equals(sourceBuffer.appendWindowStart, 0);
                    assert_equals(sourceBuffer.appendWindowEnd, Number.POSITIVE_INFINITY);
                }));
                sourceBuffer.addEventListener('update', t.step_func(function(e) {
                    assert_unreached("Can't touch this");
                }));
                sourceBuffer.addEventListener('updateend', function(e) {
                    events.push('updateend');
                    mediaSource.endOfStream();
                });
                sourceBuffer.addEventListener('abort', function(e) {
                    events.push('abort');
                });
                sourceBuffer.addEventListener('error', t.step_func(function(e) {
                    assert_unreached("Can't touch this");
                }));
                sourceBuffer.appendBuffer(data);
            }));
            mediaSource.addEventListener('sourceended', t.step_func_done(function(e) {
                assert_array_equals(events,
                                    ['updatestart', 'abort', 'updateend'],
                                    'Check the sequence of fired events.');
            }));
            var video = document.createElement('video');
            video.src = window.URL.createObjectURL(mediaSource);
        });
    }, 'SourceBuffer#abort() (' + mime + ') : Check the algorithm when the updating attribute is true.');
}
for(var file in contents) {
    mediaTest(file, contents[file]);
}
</script>
</body>
</html>