summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/secure-contexts/basic-shared-worker.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
commit43a97878ce14b72f0981164f87f2e35e14151312 (patch)
tree620249daf56c0258faa40cbdcf9cfba06de2a846 /testing/web-platform/tests/secure-contexts/basic-shared-worker.html
parentInitial commit. (diff)
downloadfirefox-43a97878ce14b72f0981164f87f2e35e14151312.tar.xz
firefox-43a97878ce14b72f0981164f87f2e35e14151312.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/secure-contexts/basic-shared-worker.html')
-rw-r--r--testing/web-platform/tests/secure-contexts/basic-shared-worker.html69
1 files changed, 69 insertions, 0 deletions
diff --git a/testing/web-platform/tests/secure-contexts/basic-shared-worker.html b/testing/web-platform/tests/secure-contexts/basic-shared-worker.html
new file mode 100644
index 0000000000..76c28a36e4
--- /dev/null
+++ b/testing/web-platform/tests/secure-contexts/basic-shared-worker.html
@@ -0,0 +1,69 @@
+<!doctype html>
+<html>
+ <head>
+ <meta charset=utf-8>
+ <title>Test SharedWorkerGlobalScope.isSecureContext for HTTP creator</title>
+ <meta name="help" href="https://w3c.github.io/webappsec-secure-contexts/#monkey-patching-global-object">
+ <script src=/resources/testharness.js></script>
+ <script src=/resources/testharnessreport.js></script>
+ <script src="server-locations.sub.js"></script>
+ </head>
+ <body>
+ <script>
+ var t1 = async_test("Shared worker");
+ var t2 = async_test("Nested worker in shared worker");
+ var t3 = async_test("Shared worker from https subframe");
+ var t4 = async_test("Nested worker from shared worker from https subframe");
+ // Tests for SharedWorkers used from other workers (not supported right
+ // now) would go here.
+
+ t1.step(function() {
+ var w = new SharedWorker("support/shared-worker-script.js");
+ w.port.onmessage = t1.step_func_done(function(e) {
+ assert_false(e.data);
+ });
+ w.port.start();
+ });
+
+ t2.step(function() {
+ var w = new SharedWorker("support/parent-shared-worker-script.js");
+ w.port.onmessage = t2.step_func_done(function(e) {
+ assert_false(e.data);
+ });
+ w.port.start();
+ });
+
+ onmessage = function(e) {
+ var data = e.data;
+ if (data.type == "shared") {
+ t3.step(function() {
+ assert_false(data.exception);
+ assert_false(data.error);
+ assert_false(data.isSecureContext);
+ });
+ t3.done();
+ } else if (data.type == "nested") {
+ t4.step(function() {
+ assert_false(data.exception);
+ assert_false(data.error);
+ assert_false(data.isSecureContext);
+ });
+ t4.done();
+ } else {
+ t3.step(function() {
+ assert_unreached("Unknown message");
+ });
+ t3.done();
+ t4.step(function() {
+ assert_unreached("Unknown message");
+ });
+ t4.done();
+ }
+ }
+
+ var ifr = document.createElement("iframe");
+ ifr.src = https_dir2 + "support/https-subframe-shared.html";
+ document.body.appendChild(ifr);
+ </script>
+ </body>
+</html>