summaryrefslogtreecommitdiffstats
path: root/dom/media/mediasource/test/test_MediaSource_mp4.html
blob: 2ab79f37f3ee1c8dd90c26551a37a6106cce509b (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
<!DOCTYPE HTML>
<html>
<head>
  <title>MSE: basic functionality</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <script type="text/javascript" src="mediasource.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
</head>
<body>
<pre id="test">
<script class="testbody" type="text/javascript">

SimpleTest.waitForExplicitFinish();

runWithMSE(async (ms, v) => {
  SimpleTest.doesThrow(() => new SourceBuffer, "new SourceBuffer should fail");
  SimpleTest.doesThrow(() => new SourceBufferList, "new SourceBufferList direct should fail");

  ok(ms instanceof EventTarget, "MediaSource must be an EventTarget");
  is(ms.readyState, "closed", "New MediaSource must be in closed state");

  // Wrapper creation, tests for leaks.
  SpecialPowers.wrap(ms);

  // Set an expando to force wrapper creation, tests for leaks.
  ms.foo = null;

  ok(URL.createObjectURL(ms), "Create an objectURL from the MediaSource");

  let loadedmetadataCount = 0;
  let updatestartCount = 0;
  let updateendCount = 0;
  let updateCount = 0;

  await once(ms, "sourceopen");
  ok(true, "Receive a sourceopen event");
  is(ms.readyState, "open", "MediaSource must be in open state after sourceopen");
  const sb = ms.addSourceBuffer("video/mp4");
  ok(sb, "Create a SourceBuffer");
  is(ms.sourceBuffers.length, 1, "MediaSource.sourceBuffers is expected length");
  is(ms.sourceBuffers[0], sb, "SourceBuffer in list matches our SourceBuffer");
  is(ms.activeSourceBuffers.length, 0, "MediaSource.activeSourceBuffers is expected length");

  sb.appendBuffer(new Uint8Array(await fetchWithXHR("bipbop/bipbop2s.mp4")));
  is(sb.updating, true, "SourceBuffer.updating is expected value after appendBuffer");

  sb.addEventListener("update", () => {
    is(sb.updating, false, "SourceBuffer.updating is expected value in update event");
    updateCount++;
    /* Ensure that we endOfStream on the first update event only as endOfStream can
       raise more if the duration of the last buffered range and the intial duration
       differ. See bug 1065207 */
    if (updateCount == 1) {
      ms.endOfStream();
    }
  });

  sb.addEventListener("updatestart", () => updatestartCount++);

  sb.addEventListener("updateend", () => {
    is(ms.activeSourceBuffers[0], sb, "SourceBuffer in active list matches our SourceBuffer");
    is(sb.updating, false, "SourceBuffer.updating is expected value in updateend event");
    updateendCount++;
    v.play();
  });

  ms.addEventListener("sourceended", () => {
    ok(true, "Receive a sourceended event");
    is(ms.readyState, "ended", "MediaSource must be in ended state after sourceended");
  });

  v.addEventListener("loadedmetadata", () => loadedmetadataCount++);

  await once(v, "ended");
  // The bipbop video doesn't start at 0. The old MSE code adjust the
  // timestamps and ignore the audio track. The new one doesn't.
  isfuzzy(v.duration, 1.696, 0.166, "Video has correct duration");
  isfuzzy(v.currentTime, 1.696, 0.166, "Video has correct duration");
  // XXX: 2 update events can be received dueto duration differences, see bug 1065207.
  ok(updateCount == 1 || updateCount == 2, "update event received");
  ok(updateendCount == 1 || updateendCount == 2, "updateend event received");
  ok(updatestartCount == 1 || updatestartCount == 2, "updatestart event received");
  is(loadedmetadataCount, 1, "loadedmetadata event received");
  SimpleTest.finish();
});

</script>
</pre>
</body>
</html>