File: test_streams_firstframe.html

package info (click to toggle)
firefox 148.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,719,656 kB
  • sloc: cpp: 7,618,171; javascript: 6,701,506; ansic: 3,781,787; python: 1,418,364; xml: 638,647; asm: 438,962; java: 186,285; sh: 62,885; makefile: 19,010; objc: 13,092; perl: 12,763; yacc: 4,583; cs: 3,846; pascal: 3,448; lex: 1,720; ruby: 1,003; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10; exp: 6
file content (67 lines) | stat: -rw-r--r-- 1,988 bytes parent folder | download | duplicates (25)
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
<!DOCTYPE HTML>
<html>
<head>
  <title>Test that a non-autoplaying, non-playing element with a MediaStream source triggers canplay and shows a first frame</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <script src="manifest.js"></script>
  <script src="/tests/dom/canvas/test/captureStream_common.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
</head>
<body>
<pre id="test">
<script class="testbody" type="text/javascript">

async function runTest() {
  const canvas = document.createElement("canvas");
  canvas.getContext("2d");
  const helper = new CaptureStreamTestHelper2D(100, 100);

  const video = document.createElement("video");
  document.body.appendChild(video);

  video.srcObject = canvas.captureStream();
  helper.drawColor(canvas, helper.red);

  await Promise.race([
    new Promise(r => video.oncanplay = r),
    new Promise(r => setTimeout(r, 30000))
      .then(() => Promise.reject(new Error("Canplay timeout"))),
  ]);

  ok(true, "Got \"canplay\"");
  is(video.readyState, video.HAVE_ENOUGH_DATA, "Expected readyState");
  ok(helper.isPixel(helper.getPixel(video), helper.red),
    "First frame is rendered before playing");

  helper.drawColor(canvas, helper.green);
  await helper.pixelMustNotBecome(video, helper.green, {
    time: 1000,
    infoString: "Rendered first frame doesn't change on new frame from source"
  });
  ok(helper.isPixel(helper.getPixel(video), helper.red),
    "First frame is still rendered");

  video.play();
  helper.drawColor(canvas, helper.blue);
  await helper.pixelMustBecome(video, helper.blue, {
    infoString: "New frame gets rendered when playing"
  });

  video.srcObject.getTracks().forEach(t => t.stop());
}

(async function() {
  SimpleTest.waitForExplicitFinish();
  SimpleTest.requestFlakyTimeout("Explicit timeout reasons");
  try {
    await runTest();
  } catch(e) {
    ok(false, e);
  }
  SimpleTest.finish();
})();

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