From 0b6210cd37b68b94252cb798598b12974a20e1c1 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Tue, 21 May 2024 22:56:19 +0200 Subject: Adding upstream version 5.28.2+dfsg1+~cs23.11.12.3. Signed-off-by: Daniel Baumann --- test/wpt/tests/xhr/resources/inspect-headers.py | 36 +++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 test/wpt/tests/xhr/resources/inspect-headers.py (limited to 'test/wpt/tests/xhr/resources/inspect-headers.py') diff --git a/test/wpt/tests/xhr/resources/inspect-headers.py b/test/wpt/tests/xhr/resources/inspect-headers.py new file mode 100644 index 0000000..123d637 --- /dev/null +++ b/test/wpt/tests/xhr/resources/inspect-headers.py @@ -0,0 +1,36 @@ +from wptserve.utils import isomorphic_encode + +def get_response(raw_headers, filter_value, filter_name): + result = b"" + # raw_headers.raw_items() returns the (name, value) header pairs as + # tuples of strings. Convert them to bytes before comparing. + # TODO: Get access to the raw headers, so that whitespace between + # name, ":" and value can also be checked: + # https://github.com/web-platform-tests/wpt/issues/28756 + for field in raw_headers.raw_items(): + name = isomorphic_encode(field[0]) + value = isomorphic_encode(field[1]) + if filter_value: + if value == filter_value: + result += name + b"," + elif name.lower() == filter_name: + result += name + b": " + value + b"\n" + return result + +def main(request, response): + headers = [] + if b"cors" in request.GET: + headers.append((b"Access-Control-Allow-Origin", b"*")) + headers.append((b"Access-Control-Allow-Credentials", b"true")) + headers.append((b"Access-Control-Allow-Methods", b"GET, POST, PUT, FOO")) + headers.append((b"Access-Control-Allow-Headers", b"x-test, x-foo")) + headers.append(( + b"Access-Control-Expose-Headers", + b"x-request-method, x-request-content-type, x-request-query, x-request-content-length")) + headers.append((b"content-type", b"text/plain")) + + filter_value = request.GET.first(b"filter_value", b"") + filter_name = request.GET.first(b"filter_name", b"").lower() + result = get_response(request.raw_headers, filter_value, filter_name) + + return headers, result -- cgit v1.2.3