summaryrefslogtreecommitdiffstats
path: root/dom/media/test/test_background_video_drawimage_with_suspended_video.html
blob: 32bda51dbffe4bbe9fc1828c923d25d8eb24422e (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
<!DOCTYPE html>
<meta charset="utf-8">
<title>Test Background Video Displays Video Frame via drawImage When Suspended</title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<script src="manifest.js"></script>
<script src="background_video.js"></script>
<link rel="stylesheet" href="/tests/SimpleTest/test.css"/>
<style>
video, canvas {
  border: 1px solid black;
}
</style>
<script type="text/javascript">
"use strict";

var manager = new MediaTestManager;

function drawVideoToCanvas(v) {
  console.log('drawVideoToCanvas');
  let c = document.createElement('canvas');
  c.width = 4;
  c.height = 4;
  c.style.width = 64;
  c.style.height = 64;
  document.body.appendChild(c);

  let gfx = c.getContext('2d');
  if (!gfx) {
    throw Error("Unable to obtain context '2d' from canvas");
  }

  gfx.drawImage(v, 0, 0, 4, 4);
  let imageData = gfx.getImageData(0, 0, 4, 4);
  let pixels = imageData.data;

  // Check that pixels aren't all the same colour.
  // Implements by checking against rgb of the first pixel.
  let rr = pixels[0],
      gg = pixels[1],
      bb = pixels[2],
      allSame = true;

  for (let i = 0; i < 4*4; i++) {
    let r = pixels[4*i+0];
    let g = pixels[4*i+1];
    let b = pixels[4*i+2];
    if (r != rr || g != gg || b != bb) {
      allSame = false;
      break;
    }
  }

  ok(!allSame, "Pixels aren't all the same color");
}

startTest({
  desc: 'Test Background Video Displays Video Frame via drawImage When Suspended',
  prefs: [
    [ "media.test.video-suspend", true ],
    [ "media.suspend-bkgnd-video.enabled", true ],
    [ "media.suspend-bkgnd-video.delay-ms", 500 ]
  ],
  tests: gDecodeSuspendTests,
  runTest: (test, token) => {
    let v = appendVideoToDoc(test.name, token);
    manager.started(token);

    waitUntilPlaying(v)
      .then(() => testVideoSuspendsWhenHidden(v))
      .then(() => {
        drawVideoToCanvas(v);
        manager.finished(token);
      });
  }
});
</script>