File: HTMLCanvasElement-getImageData-noframe.html

package info (click to toggle)
firefox-esr 140.5.0esr-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,538,920 kB
  • sloc: cpp: 7,381,527; javascript: 6,388,905; ansic: 3,710,087; python: 1,393,776; xml: 628,165; asm: 426,916; java: 184,004; sh: 65,744; makefile: 19,302; objc: 13,059; perl: 12,912; yacc: 4,583; cs: 3,846; pascal: 3,352; lex: 1,720; ruby: 1,226; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (30 lines) | stat: -rw-r--r-- 987 bytes parent folder | download | duplicates (22)
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
<!DOCTYPE html>
<html>
<body>
<canvas id="canvas"></canvas>
<script src=/resources/testharness.js></script>
<script src=/resources/testharnessreport.js></script>
<script>
promise_test(async t => {
  const canvas = document.getElementById("canvas");
  const ctx = canvas.getContext("2d");
  const stream = canvas.captureStream();
  t.add_cleanup(() => stream.getTracks().forEach(track => track.stop()));

  const video = document.createElement("video");
  video.srcObject = stream;

  ctx.getImageData(0, 0, canvas.width, canvas.height);

  assert_equals(video.readyState, video.HAVE_NOTHING,
    "Video element was just created");

  // Wait a bit so the video element can update readyState in case of a frame.
  await new Promise(r => t.step_timeout(r, 100));

  assert_equals(video.readyState, video.HAVE_NOTHING,
    "Video element did not get a frame from the canvas");
}, "CanvasRenderingContext2D.getImageData() does not lead to a frame being captured");
</script>
</body>
</html>