summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/resource-timing/SyntheticResponse.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /testing/web-platform/tests/resource-timing/SyntheticResponse.py
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/resource-timing/SyntheticResponse.py')
-rw-r--r--testing/web-platform/tests/resource-timing/SyntheticResponse.py50
1 files changed, 50 insertions, 0 deletions
diff --git a/testing/web-platform/tests/resource-timing/SyntheticResponse.py b/testing/web-platform/tests/resource-timing/SyntheticResponse.py
new file mode 100644
index 0000000000..6f888f3789
--- /dev/null
+++ b/testing/web-platform/tests/resource-timing/SyntheticResponse.py
@@ -0,0 +1,50 @@
+from urllib.parse import unquote
+
+from wptserve.utils import isomorphic_decode, isomorphic_encode
+
+import importlib
+sleep = importlib.import_module("resource-timing.sleep")
+
+def main(request, response):
+ index = isomorphic_encode(request.request_path).index(b"?")
+ args = isomorphic_encode(request.request_path[index+1:]).split(b"&")
+ headers = []
+ statusSent = False
+ headersSent = False
+ for arg in args:
+ if arg.startswith(b"ignored"):
+ continue
+ elif arg.endswith(b"ms"):
+ sleep.sleep_at_least(float(arg[0:-2]))
+ elif arg.startswith(b"redirect:"):
+ return (302, u"WEBPERF MARKETING"), [(b"Location", unquote(isomorphic_decode(arg[9:])))], u"TEST"
+
+ elif arg.startswith(b"mime:"):
+ headers.append((b"Content-Type", unquote(isomorphic_decode(arg[5:]))))
+
+ elif arg.startswith(b"send:"):
+ text = unquote(isomorphic_decode(arg[5:]))
+
+ if not statusSent:
+ # Default to a 200 status code.
+ response.writer.write_status(200)
+ statusSent = True
+ if not headersSent:
+ for key, value in headers:
+ response.writer.write_header(key, value)
+ response.writer.end_headers()
+ headersSent = True
+
+ response.writer.write_content(text)
+ elif arg.startswith(b"status:"):
+ code = int(unquote(isomorphic_decode(arg[7:])))
+ response.writer.write_status(code)
+ if code // 100 == 1:
+ # Terminate informational 1XX responses with an empty line.
+ response.writer.end_headers()
+ else:
+ statusSent = True
+
+# else:
+# error " INVALID ARGUMENT %s" % arg
+