summaryrefslogtreecommitdiffstats
path: root/dom/canvas/test/offscreencanvas_serviceworker_inner.html
blob: b153f9524a1c1dfcc5d934fe8e80d14f59f4ced7 (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
<!DOCTYPE HTML>
<html>
<head>
<title>WebGL in OffscreenCanvas</title>
</head>
<body>
<canvas id="c" width="64" height="64"></canvas>
<script>
function ok(expect, msg) {
  parent.postMessage({type: "test", result: !!expect, name: msg}, "*");
}

var htmlCanvas = document.getElementById("c");

ok(htmlCanvas, "Should have HTML canvas element");

var messageChannel = new MessageChannel();
messageChannel.port1.onmessage = function(evt) {
  parent.postMessage(evt.data, "*");
}

ok(htmlCanvas.transferControlToOffscreen, "HTMLCanvasElement has transferControlToOffscreen function");

var offscreenCanvas = htmlCanvas.transferControlToOffscreen();
ok(offscreenCanvas, "Expected transferControlToOffscreen to succeed");

navigator.serviceWorker.ready.then(function() {
  navigator.serviceWorker.controller.postMessage({test: 'webgl', canvas: offscreenCanvas}, [offscreenCanvas, messageChannel.port2]);
});
</script>
</body>
</html>