summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/html/semantics/embedded-content/media-elements/track/track-element/no-cuechange-before-play.html
blob: cd53914ecd574f280247af4b35f1e336f269bf37 (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
<!DOCTYPE html>
<title>Ensure that the 'cuechange' event is not fired before video playback has begun.</title>
<script src="/common/media.js"></script>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script>
promise_test(function(t) {
    let video = document.createElement('video');
    video.src = getVideoURI('/media/movie_5');
    video.preload = 'auto';

    // Create a track element. The 'cuechange' event should not be fired.
    let track = document.createElement('track');
    track.oncuechange = t.unreached_func('The \`cuechange\` event should not be fired');

    let videoWatcher = new EventWatcher(t, video, 'canplaythrough');
    let trackWatcher = new EventWatcher(t, track, ['cuechange', 'load'])

    track.src = 'resources/captions-fast.vtt';
    track.kind = 'captions';
    track.default = true;
    track.track.mode = 'showing';
    video.appendChild(track);

    return Promise.all([videoWatcher.wait_for('canplaythrough'), trackWatcher.wait_for('load')]);
});
</script>