diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /testing/web-platform/tests/xhr/access-control-preflight-request-must-not-contain-cookie.htm | |
parent | Initial commit. (diff) | |
download | thunderbird-upstream.tar.xz thunderbird-upstream.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/xhr/access-control-preflight-request-must-not-contain-cookie.htm')
-rw-r--r-- | testing/web-platform/tests/xhr/access-control-preflight-request-must-not-contain-cookie.htm | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/testing/web-platform/tests/xhr/access-control-preflight-request-must-not-contain-cookie.htm b/testing/web-platform/tests/xhr/access-control-preflight-request-must-not-contain-cookie.htm new file mode 100644 index 0000000000..6dd8e6db88 --- /dev/null +++ b/testing/web-platform/tests/xhr/access-control-preflight-request-must-not-contain-cookie.htm @@ -0,0 +1,57 @@ +<!DOCTYPE html> +<html> + <head> + <title>Preflight request must not contain any cookie header</title> + <script src="/resources/testharness.js"></script> + <script src="/resources/testharnessreport.js"></script> + <script src="/common/get-host-info.sub.js"></script> + </head> + <body> + <script type="text/javascript"> + async_test((test) => { + function setupCookie() { + const xhr = new XMLHttpRequest; + // Delete all preexisting cookies and set a cookie named "foo" + xhr.open("GET", get_host_info().HTTP_REMOTE_ORIGIN + + "/xhr/resources/access-control-cookie.py?cookie_name=foo"); + xhr.withCredentials = true; + xhr.send(); + xhr.onerror = test.unreached_func("Unexpected error."); + xhr.onload = test.step_func(() => { + assert_equals(xhr.status, 200); + sendPreflightedRequest(); + }); + } + + function sendPreflightedRequest() { + const xhr = new XMLHttpRequest; + // Request to server-side file fails if cookie is included in preflight + xhr.open("GET", get_host_info().HTTP_REMOTE_ORIGIN + + "/xhr/resources/access-control-preflight-request-must-not-contain-cookie.py"); + xhr.withCredentials = true; + xhr.setRequestHeader("X-Proprietary-Header", "foo"); + xhr.onerror = test.unreached_func("Unexpected error."); + xhr.onload = test.step_func(() => { + assert_equals(xhr.status, 200); + assert_equals(xhr.responseText, "COOKIE"); + cleanupCookies(); + }); + xhr.send(); + } + + function cleanupCookies() { + const xhr = new XMLHttpRequest; + // Delete all cookies + xhr.open("GET", get_host_info().HTTP_REMOTE_ORIGIN + + "/xhr/resources/access-control-cookie.py"); + xhr.withCredentials = true; + xhr.send(); + xhr.onerror = test.unreached_func("Unexpected error."); + xhr.onload = test.step_func_done(() => {}); + } + + setupCookie(); + }); + </script> + </body> +</html> |