diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /dom/canvas/test/test_offscreencanvas_subworker.html | |
parent | Initial commit. (diff) | |
download | thunderbird-upstream.tar.xz thunderbird-upstream.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/canvas/test/test_offscreencanvas_subworker.html')
-rw-r--r-- | dom/canvas/test/test_offscreencanvas_subworker.html | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/dom/canvas/test/test_offscreencanvas_subworker.html b/dom/canvas/test/test_offscreencanvas_subworker.html new file mode 100644 index 0000000000..b3fbae821c --- /dev/null +++ b/dom/canvas/test/test_offscreencanvas_subworker.html @@ -0,0 +1,90 @@ +<!DOCTYPE HTML> +<html> +<head> +<title>OffscreenCanvas: Test subworkers</title> +<script src="/tests/SimpleTest/SimpleTest.js"></script> +<link rel="stylesheet" href="/tests/SimpleTest/test.css"> +</head> +<body> +<!-- + We want to test offscreen canvas works well when it running on worker + and nested worker simultaneously. So we create 10 canvas and dispatch + it to different workers and sub-workers. +--> +<script> + +SimpleTest.waitForExplicitFinish(); + +function createCanvas() { + var htmlCanvas = document.createElement('canvas'); + htmlCanvas.width = 64; + htmlCanvas.height = 64; + document.body.appendChild(htmlCanvas); + return htmlCanvas.transferControlToOffscreen(); +} + +function runTest() { + + var worker = new Worker("offscreencanvas.js"); + + worker.onmessage = function(evt) { + var msg = evt.data || {}; + if (msg.type == "test") { + ok(msg.result, msg.name); + } + if (msg.type == "finish") { + worker.terminate(); + SimpleTest.finish(); + } + } + + var findTransferables = function(t) { + if (t.test == "subworker") { + var result = []; + t.subtests.forEach(function(test) { + result = result.concat(findTransferables(test)); + }); + + return result; + } else { + return [t.canvas]; + } + }; + + var testData = + {test: 'subworker', subtests: [ + {test: 'webgl', canvas: createCanvas()}, + {test: 'subworker', subtests: [ + {test: 'webgl', canvas: createCanvas()}, + {test: 'webgl_changesize', canvas: createCanvas()}, + {test: 'webgl', canvas: createCanvas()} + ]}, + {test: 'subworker', subtests: [ + {test: 'webgl', canvas: createCanvas()}, + {test: 'webgl_changesize', canvas: createCanvas()}, + {test: 'subworker', subtests: [ + {test: 'webgl_changesize', canvas: createCanvas()}, + {test: 'webgl', canvas: createCanvas()} + ]}, + {test: 'subworker', subtests: [ + {test: 'webgl_changesize', canvas: createCanvas()}, + {test: 'subworker', subtests: [ + {test: 'subworker', subtests: [ + {test: 'webgl_changesize', canvas: createCanvas()} + ]} + ]} + ]}, + ]} + ]}; + + worker.postMessage(testData, findTransferables(testData)); +} + +SpecialPowers.pushPrefEnv({'set': [ + ['gfx.offscreencanvas.enabled', true], + ['webgl.force-enabled', true], +]}, runTest); + +</script> +</body> +</html> |