summaryrefslogtreecommitdiffstats
path: root/browser/components/contextualidentity/test/browser/saveLink.sjs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
commit6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch)
treea68f146d7fa01f0134297619fbe7e33db084e0aa /browser/components/contextualidentity/test/browser/saveLink.sjs
parentInitial commit. (diff)
downloadthunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz
thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.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 'browser/components/contextualidentity/test/browser/saveLink.sjs')
-rw-r--r--browser/components/contextualidentity/test/browser/saveLink.sjs55
1 files changed, 55 insertions, 0 deletions
diff --git a/browser/components/contextualidentity/test/browser/saveLink.sjs b/browser/components/contextualidentity/test/browser/saveLink.sjs
new file mode 100644
index 0000000000..bbdb756364
--- /dev/null
+++ b/browser/components/contextualidentity/test/browser/saveLink.sjs
@@ -0,0 +1,55 @@
+const HTTP_ORIGIN = "http://example.com";
+const HTTPS_ORIGIN = "https://example.com";
+const URI_PATH =
+ "/browser/browser/components/contextualidentity/test/browser/saveLink.sjs";
+
+Cu.importGlobalProperties(["URLSearchParams"]);
+
+function handleRequest(aRequest, aResponse) {
+ var params = new URLSearchParams(aRequest.queryString);
+
+ // This is the first request, where we set the cookie.
+ if (params.has("UCI")) {
+ aResponse.setStatusLine(aRequest.httpVersion, 200);
+ aResponse.setHeader("Set-Cookie", "UCI=" + params.get("UCI"));
+ aResponse.write(
+ "<html><body><a href='" +
+ HTTPS_ORIGIN +
+ URI_PATH +
+ "?redirect=1' id='fff'>this is a link</a></body></html>"
+ );
+ return;
+ }
+
+ // Second request. This is the save-as content, but we make a redirect to see
+ // if we are able to follow it.
+ if (params.has("redirect")) {
+ aResponse.setStatusLine(aRequest.httpVersion, 302, "Found");
+ aResponse.setHeader(
+ "Location",
+ HTTP_ORIGIN + URI_PATH + "?download=1",
+ false
+ );
+ aResponse.write("Redirect!");
+ return;
+ }
+
+ // This is the 3rd request where we offer the content to be saved.
+ if (params.has("download")) {
+ setState("downloadUCI", aRequest.getHeader("Cookie"));
+ aResponse.setStatusLine(aRequest.httpVersion, 200);
+ aResponse.write("All Good!");
+ return;
+ }
+
+ // This is the last request to check that the download happened with the correct cookie
+ if (params.has("result")) {
+ aResponse.setStatusLine(aRequest.httpVersion, 200);
+ aResponse.write("Result:" + getState("downloadUCI"));
+ return;
+ }
+
+ // We should not be here!
+ aResponse.setStatusLine(aRequest.httpVersion, 500);
+ aResponse.write("ERROR!!!");
+}