diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | 5f8de423f190bbb79a62f804151bc24824fa32d8 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /dom/canvas/test/test_offscreencanvas_toblob.html | |
parent | 49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff) | |
download | UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip |
Add m-esr52 at 52.6.0
Diffstat (limited to 'dom/canvas/test/test_offscreencanvas_toblob.html')
-rw-r--r-- | dom/canvas/test/test_offscreencanvas_toblob.html | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/dom/canvas/test/test_offscreencanvas_toblob.html b/dom/canvas/test/test_offscreencanvas_toblob.html new file mode 100644 index 000000000..d5cc2c02d --- /dev/null +++ b/dom/canvas/test/test_offscreencanvas_toblob.html @@ -0,0 +1,91 @@ +<!DOCTYPE HTML> +<html> +<head> +<title>WebGL in OffscreenCanvas</title> +<script src="/tests/SimpleTest/SimpleTest.js"></script> +<script src="offscreencanvas.js"></script> +<link rel="stylesheet" href="/tests/SimpleTest/test.css"> +</head> +<body> +<canvas id="c" width="64" height="64"></canvas> +<canvas id="c-mt" width="64" height="64"></canvas> +<canvas id="c-ref" width="64" height="64"></canvas> +<script> + +SimpleTest.waitForExplicitFinish(); + +function testBlob(blob, callback) { + // testing toBlob + // Fill c-ref with green color. + var c = document.getElementById("c-ref"); + var ctx = c.getContext("2d"); + ctx.rect(0, 0, 64, 64); + ctx.fillStyle = "#00FF00"; + ctx.fill(); + var reader = new FileReader(); + reader.onload = function(e) { + ok(c.toDataURL() == e.target.result, "toBlob should return a 64x64 green square"); + callback(); + }; + reader.readAsDataURL(blob); +} + +function runTestOnMainThread() { + var htmlCanvas = document.getElementById("c-mt"); + ok(htmlCanvas, "Should have HTML canvas element"); + + window.onmessage = function(evt) { + var msg = evt.data || {}; + if (msg.type == "test") { + ok(msg.result, msg.name); + } + if (msg.type == "blob") { + testBlob(msg.blob, SimpleTest.finish); + } + } + + ok(htmlCanvas.transferControlToOffscreen, "HTMLCanvasElement has transferControlToOffscreen function"); + + var offscreenCanvas = htmlCanvas.transferControlToOffscreen(); + ok(offscreenCanvas, "Expected transferControlToOffscreen to succeed"); + + entryFunction('webgl_toblob', '', offscreenCanvas); +} + +function runTest() { + + var htmlCanvas = document.getElementById("c"); + var worker = new Worker("offscreencanvas.js"); + + ok(htmlCanvas, "Should have HTML canvas element"); + ok(worker, "Web worker successfully created"); + + worker.onmessage = function(evt) { + var msg = evt.data || {}; + if (msg.type == "test") { + ok(msg.result, msg.name); + } + if (msg.type == "blob") { + testBlob(msg.blob, function() { + worker.terminate(); + runTestOnMainThread(); + }); + } + } + + ok(htmlCanvas.transferControlToOffscreen, "HTMLCanvasElement has transferControlToOffscreen function"); + + var offscreenCanvas = htmlCanvas.transferControlToOffscreen(); + ok(offscreenCanvas, "Expected transferControlToOffscreen to succeed"); + + worker.postMessage({test: 'webgl_toblob', canvas: offscreenCanvas}, [offscreenCanvas]); +} + +SpecialPowers.pushPrefEnv({'set': [ + ['gfx.offscreencanvas.enabled', true], + ['webgl.force-enabled', true], +]}, runTest); + +</script> +</body> +</html> |