summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/loading/early-hints/invalid-headers-in-early-hints.h2.window.js
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/loading/early-hints/invalid-headers-in-early-hints.h2.window.js
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/loading/early-hints/invalid-headers-in-early-hints.h2.window.js')
-rw-r--r--testing/web-platform/tests/loading/early-hints/invalid-headers-in-early-hints.h2.window.js22
1 files changed, 22 insertions, 0 deletions
diff --git a/testing/web-platform/tests/loading/early-hints/invalid-headers-in-early-hints.h2.window.js b/testing/web-platform/tests/loading/early-hints/invalid-headers-in-early-hints.h2.window.js
new file mode 100644
index 0000000000..55181877df
--- /dev/null
+++ b/testing/web-platform/tests/loading/early-hints/invalid-headers-in-early-hints.h2.window.js
@@ -0,0 +1,22 @@
+async function testInvalidHeader(t, header_value) {
+ const params = new URLSearchParams();
+ params.set("header-value", header_value);
+ const test_url = "resources/invalid-headers-in-early-hints.h2.py?" + params.toString();
+ const opened_window = window.open(test_url, "invalid-header-in-early-hints");
+
+ // Use step_timeout() because neither "load" event nor postMessage() would
+ // work. Opening the test page should result in a network protocol error and
+ // accessing the document of the opened window should throw a SecurityError.
+ await new Promise(resolve => t.step_timeout(resolve, 1000));
+ assert_throws_dom("SecurityError", () => {
+ opened_window.document;
+ }, "window.open() should not load the test page successfully.");
+}
+
+promise_test(async (t) => {
+ await testInvalidHeader(t, "foo\r\nbar");
+}, "Early Hints contains invalid header: newline byte");
+
+promise_test(async (t) => {
+ await testInvalidHeader(t, "foo\x00bar");
+}, "Early Hints contains invalid header: nul byte");