summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/xhr/resources/no-custom-header-on-preflight.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 01:47:29 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 01:47:29 +0000
commit0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d (patch)
treea31f07c9bcca9d56ce61e9a1ffd30ef350d513aa /testing/web-platform/tests/xhr/resources/no-custom-header-on-preflight.py
parentInitial commit. (diff)
downloadfirefox-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/xhr/resources/no-custom-header-on-preflight.py')
-rw-r--r--testing/web-platform/tests/xhr/resources/no-custom-header-on-preflight.py27
1 files changed, 27 insertions, 0 deletions
diff --git a/testing/web-platform/tests/xhr/resources/no-custom-header-on-preflight.py b/testing/web-platform/tests/xhr/resources/no-custom-header-on-preflight.py
new file mode 100644
index 0000000000..835c12813d
--- /dev/null
+++ b/testing/web-platform/tests/xhr/resources/no-custom-header-on-preflight.py
@@ -0,0 +1,27 @@
+def main(request, response):
+ def getState(token):
+ server_state = request.server.stash.take(token)
+ if not server_state:
+ return b"Uninitialized"
+ return server_state
+
+ def setState(state, token):
+ request.server.stash.put(token, state)
+
+ response.headers.set(b"Access-Control-Allow-Origin", b"*")
+ response.headers.set(b"Access-Control-Allow-Headers", b"x-test")
+ response.headers.set(b"Access-Control-Max-Age", 0)
+ token = request.GET.first(b"token", None)
+
+ if request.method == u"OPTIONS":
+ if request.headers.get(b"x-test"):
+ response.content = b"FAIL: Invalid header in preflight request."
+ response.status = 400
+ else:
+ setState(b"PASS", token)
+ else:
+ if request.headers.get(b"x-test"):
+ response.content = getState(token)
+ else:
+ response.content = b"FAIL: X-Test header missing in request"
+ response.status = 400