summaryrefslogtreecommitdiffstats
path: root/dom/media/webvtt/test/mochitest/test_bug895091.html
blob: 6fa262928335e0cf7ca7c965b1894963b16b83fb (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
<!DOCTYPE HTML>
<html>
<head>
  <title>Test for Bug 895091 - Integrating vtt.js</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <script type="text/javascript" src="manifest.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
</head>
<body>
<video id="v" src="seek.webm" preload="metadata">
  <track src="long.vtt" kind="subtitles" id="track1">
  <track src="long.vtt" kind="subtitles" id="track2">
</video>
<script type="text/javascript">
/**
 * This test is used to ensure that we can load two track elements with large
 * amount of cues at same time. In this test, both tracks are disable by default,
 * we have to enable them in order to start loading.
 */
var trackElement = document.getElementById("track1");
var trackElementTwo = document.getElementById("track2");

async function runTest() {
  enableBothTracks();
  await waitUntilBothTracksLoaded();
  checkTrackReadyStateShouldBeLoaded();
  checkCuesAmount();
  SimpleTest.finish();
}

SimpleTest.waitForExplicitFinish();
onload = runTest;

/**
 * The following are test helper functions.
 */
function enableBothTracks() {
  // All tracks are `disable` on default. As we won't start loading for disabled
  // tracks, we have to change their mode in order to start loading.
  trackElement.track.mode = "hidden";
  trackElementTwo.track.mode = "hidden";
}

async function waitUntilBothTracksLoaded() {
  info(`wait until both tracks finish loading`);
  await Promise.all([once(trackElement, "load"), once(trackElementTwo, "load")]);
}

function checkTrackReadyStateShouldBeLoaded() {
  is(trackElement.readyState, 2, "Track::ReadyState should be set to LOADED.");
  is(trackElementTwo.readyState, 2, "Track::ReadyState should be set to LOADED.");
}

function checkCuesAmount() {
  is(trackElement.track.cues.length, 2000, "Cue list length should be 2000.");
  is(trackElementTwo.track.cues.length, 2000, "Cue list length should be 2000.");
}
</script>
</body>
</html>