summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/fenced-frame/csp.https.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /testing/web-platform/tests/fenced-frame/csp.https.html
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/fenced-frame/csp.https.html')
-rw-r--r--testing/web-platform/tests/fenced-frame/csp.https.html39
1 files changed, 39 insertions, 0 deletions
diff --git a/testing/web-platform/tests/fenced-frame/csp.https.html b/testing/web-platform/tests/fenced-frame/csp.https.html
new file mode 100644
index 0000000000..6daa6a96e8
--- /dev/null
+++ b/testing/web-platform/tests/fenced-frame/csp.https.html
@@ -0,0 +1,39 @@
+<!DOCTYPE html>
+ <title>Test Content Security Policy</title>
+ <script src="/resources/testharness.js"></script>
+ <script src="/resources/testharnessreport.js"></script>
+ <script src="resources/utils.js"></script>
+ <script src="/common/utils.js"></script>
+
+ <body>
+
+ <script>
+ promise_test(async () => {
+ const csp_key = token();
+
+ // The 'csp' property does not appear in the IDL definition for
+ // fenced frames, so ensure that the 'csp' property didn't
+ // leak over from the IFrame prototype.
+ assert_equals(HTMLFencedFrameElement.prototype.hasOwnProperty('csp'),
+ false);
+
+ const new_frame = document.createElement('fencedframe');
+ const new_config = new FencedFrameConfig(generateURL(
+ "resources/csp-inner.html",
+ [csp_key]));
+ new_frame.config = new_config;
+
+ // This attribute will be ignored since the IDL for
+ // fenced frames do not support the 'csp' attribute.
+ new_frame.setAttribute("csp", "style-src 'none';");
+ document.body.append(new_frame);
+
+ // Get the result for the top-level fenced frame.
+ const fenced_frame_result = await nextValueFromServer(csp_key);
+ assert_equals(fenced_frame_result, "pass");
+
+ }, "Fenced Frames should not honor the csp attribute from parent page");
+ </script>
+
+ </body>
+</html>