diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:47:29 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:47:29 +0000 |
commit | 0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d (patch) | |
tree | a31f07c9bcca9d56ce61e9a1ffd30ef350d513aa /testing/web-platform/tests/web-locks/bfcache/release-across-thread.tentative.https.html | |
parent | Initial commit. (diff) | |
download | firefox-esr-0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d.tar.xz firefox-esr-0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d.zip |
Adding upstream version 115.8.0esr.upstream/115.8.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/web-locks/bfcache/release-across-thread.tentative.https.html')
-rw-r--r-- | testing/web-platform/tests/web-locks/bfcache/release-across-thread.tentative.https.html | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/testing/web-platform/tests/web-locks/bfcache/release-across-thread.tentative.https.html b/testing/web-platform/tests/web-locks/bfcache/release-across-thread.tentative.https.html new file mode 100644 index 0000000000..374cee8b6d --- /dev/null +++ b/testing/web-platform/tests/web-locks/bfcache/release-across-thread.tentative.https.html @@ -0,0 +1,46 @@ +<!DOCTYPE html> +<meta charset=utf-8> +<meta name="timeout" content="long"> +<title>Web Locks API: bfcache</title> +<link rel=help href="https://w3c.github.io/web-locks/"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="/common/utils.js"></script> +<script src="/common/dispatcher/dispatcher.js"></script> +<script src="/html/browsers/browsing-the-web/back-forward-cache/resources/helper.sub.js"></script> +<script type="module"> + import { runWebLocksBfcacheTest } from "./helpers.js"; + + runWebLocksBfcacheTest({ + funcBeforeNavigation: async () => { + navigator.locks.request(uniqueNameByQuery(), () => new Promise(() => { })); + window.worker = new Worker("/web-locks/resources/worker.js"); + const { lock_id } = await postToWorkerAndWait(worker, { op: "request", name: uniqueNameByQuery() }); + await postToWorkerAndWait(worker, { op: "release", lock_id }); + }, + shouldBeCached: false, + }, "A held lock on main thread must prevent bfcache even after worker releases locks"); + + runWebLocksBfcacheTest({ + funcBeforeNavigation: async () => { + const controller = new AbortController(); + navigator.locks.request(uniqueNameByQuery(), { signal: controller.signal }, () => new Promise(() => { })); + window.worker = new Worker("/web-locks/resources/worker.js"); + await postToWorkerAndWait(worker, { op: "request", name: uniqueNameByQuery() }); + controller.abort(); + }, + shouldBeCached: false, + }, "A held lock on worker must prevent bfcache even after main thread releases locks"); + + runWebLocksBfcacheTest({ + funcBeforeNavigation: async () => { + const controller = new AbortController(); + navigator.locks.request(uniqueNameByQuery(), { signal: controller.signal }, () => new Promise(() => { })); + window.worker = new SharedWorker("/web-locks/resources/worker.js"); + worker.port.start(); + await postToWorkerAndWait(worker.port, { op: "request", name: uniqueNameByQuery() }); + controller.abort(); + }, + shouldBeCached: false, + }, "A held lock on shared worker must prevent bfcache even after main thread releases locks"); +</script> |