diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
commit | 43a97878ce14b72f0981164f87f2e35e14151312 (patch) | |
tree | 620249daf56c0258faa40cbdcf9cfba06de2a846 /testing/web-platform/tests/workers/shared-worker-from-blob-url.window.js | |
parent | Initial commit. (diff) | |
download | firefox-upstream.tar.xz firefox-upstream.zip |
Adding upstream version 110.0.1.upstream/110.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/workers/shared-worker-from-blob-url.window.js')
-rw-r--r-- | testing/web-platform/tests/workers/shared-worker-from-blob-url.window.js | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/testing/web-platform/tests/workers/shared-worker-from-blob-url.window.js b/testing/web-platform/tests/workers/shared-worker-from-blob-url.window.js new file mode 100644 index 0000000000..98e34cc3a6 --- /dev/null +++ b/testing/web-platform/tests/workers/shared-worker-from-blob-url.window.js @@ -0,0 +1,53 @@ +function message_from_port(port) { + return new Promise(resolve => { + port.onmessage = e => resolve(e.data); + }); +} + +promise_test(async t => { + const run_result = 'worker_OK_'; + const blob_contents = + 'self.counter = 0; self.onconnect = e => {++self.counter;' + + 'e.source.postMessage("' + run_result + '" + self.counter); };'; + const blob = new Blob([blob_contents]); + const url = URL.createObjectURL(blob); + + const worker1 = new SharedWorker(url); + const reply1 = await message_from_port(worker1.port); + assert_equals(reply1, run_result + '1'); + const worker2 = new SharedWorker(url); + const reply2 = await message_from_port(worker2.port); + assert_equals(reply2, run_result + '2'); +}, 'Creating a shared worker from a blob URL works.'); + +promise_test(async t => { + const run_result = 'worker_OK'; + const blob_contents = + 'self.onconnect = e => { e.source.postMessage("' + run_result + '"); };'; + const blob = new Blob([blob_contents]); + const url = URL.createObjectURL(blob); + + const worker = new SharedWorker(url); + URL.revokeObjectURL(url); + + const reply = await message_from_port(worker.port); + assert_equals(reply, run_result); +}, 'Creating a shared worker from a blob URL works immediately before revoking.'); + +promise_test(async t => { + const run_result = 'worker_OK_'; + const blob_contents = + 'self.counter = 0; self.onconnect = e => {++self.counter;' + + 'e.source.postMessage("' + run_result + '" + self.counter); };'; + const blob = new Blob([blob_contents]); + const url = URL.createObjectURL(blob); + + const worker1 = new SharedWorker(url); + URL.revokeObjectURL(url); + + const reply1 = await message_from_port(worker1.port); + assert_equals(reply1, run_result + '1'); + const worker2 = new SharedWorker(url); + const reply2 = await message_from_port(worker2.port); + assert_equals(reply2, run_result + '2'); +}, 'Connecting to a shared worker on a revoked blob URL works.'); |