diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
commit | 43a97878ce14b72f0981164f87f2e35e14151312 (patch) | |
tree | 620249daf56c0258faa40cbdcf9cfba06de2a846 /testing/web-platform/tests/xhr/resources/access-control-basic-preflight-cache.py | |
parent | Initial commit. (diff) | |
download | firefox-upstream.tar.xz firefox-upstream.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/xhr/resources/access-control-basic-preflight-cache.py')
-rw-r--r-- | testing/web-platform/tests/xhr/resources/access-control-basic-preflight-cache.py | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/testing/web-platform/tests/xhr/resources/access-control-basic-preflight-cache.py b/testing/web-platform/tests/xhr/resources/access-control-basic-preflight-cache.py new file mode 100644 index 0000000000..7a6bb60c01 --- /dev/null +++ b/testing/web-platform/tests/xhr/resources/access-control-basic-preflight-cache.py @@ -0,0 +1,50 @@ + +from wptserve.utils import isomorphic_encode + +def main(request, response): + def fail(message): + response.content = b"FAIL " + isomorphic_encode(request.method) + b": " + message + response.status = 400 + + 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", request.headers.get(b"origin")) + response.headers.set(b"Access-Control-Allow-Credentials", b"true") + token = request.GET.first(b"token", None) + state = getState(token) + + if state == b"Uninitialized": + if request.method == u"OPTIONS": + response.headers.set(b"Access-Control-Allow-Methods", b"PUT") + response.headers.set(b"Access-Control-Max-Age", 10) + setState(b"OPTIONSSent", token) + else: + fail(state) + elif state == b"OPTIONSSent": + if request.method == u"PUT": + response.content = b"PASS: First PUT request." + setState(b"FirstPUTSent", token) + else: + fail(state) + elif state == b"FirstPUTSent": + if request.method == u"PUT": + response.content = b"PASS: Second PUT request. Preflight worked." + elif request.method == u"OPTIONS": + response.headers.set(b"Access-Control-Allow-Methods", b"PUT") + setState(b"FAILSecondOPTIONSSent", token) + else: + fail(state) + elif state == b"FAILSecondOPTIONSSent": + if request.method == u"PUT": + fail(b"Second OPTIONS request was sent. Preflight failed.") + else: + fail(state) + else: + fail(state) |