summaryrefslogtreecommitdiffstats
path: root/docshell/test/mochitest/test_bug1850335.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /docshell/test/mochitest/test_bug1850335.html
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'docshell/test/mochitest/test_bug1850335.html')
-rw-r--r--docshell/test/mochitest/test_bug1850335.html72
1 files changed, 72 insertions, 0 deletions
diff --git a/docshell/test/mochitest/test_bug1850335.html b/docshell/test/mochitest/test_bug1850335.html
new file mode 100644
index 0000000000..546aab59c8
--- /dev/null
+++ b/docshell/test/mochitest/test_bug1850335.html
@@ -0,0 +1,72 @@
+<!DOCTYPE HTML>
+<html>
+<head>
+ <meta charset="utf-8">
+ <title>Test referrer with going back</title>
+ <script src="/tests/SimpleTest/SimpleTest.js"></script>
+ <link rel="stylesheet" href="/tests/SimpleTest/test.css"/>
+ <script>
+ SimpleTest.waitForExplicitFinish();
+
+ function waitForMessage(bc) {
+ return new Promise(resolve => {
+ bc.addEventListener("message", ({ data }) => { resolve(data); }, { once: true });
+ });
+ }
+
+ async function runTest() {
+ let bc = new BroadcastChannel("bug1850335");
+
+ // Load the first page.
+ let waitForPage1 = waitForMessage(bc);
+ window.open("file_bug1850335_1.html", "_blank", "noopener");
+ let { persisted, value: initial } = await waitForPage1;
+
+ ok(!persisted, "Loaded first page");
+ is(initial, "", "Initial value is empty string");
+
+ // Set the value of the input element in the first page.
+ let waitForValue = waitForMessage(bc);
+ bc.postMessage({ cmd: "setValue", arg: "ok" });
+ let { value: expected }= await waitForValue;
+ is(expected, "ok", "Loaded first page");
+
+ // Load the second page (same origin with the first page).
+ let waitForPage2 = waitForMessage(bc);
+ bc.postMessage({ cmd: "load", arg: "file_bug1850335_2.html" });
+ ({ persisted } = await waitForPage2);
+
+ ok(!persisted, "Loaded second page (same-origin)");
+
+ // Load the third page (cross origin with the first and second pages). The
+ // third page will immediately do |history.back()| to go back to the
+ // second page.
+ waitForPage2 = waitForMessage(bc);
+ const crossOrigin = new URL("file_bug1850335_3.html", `https://example.com${location.pathname}`);
+ bc.postMessage({ cmd: "load", arg: crossOrigin.href });
+ ({ persisted } = await waitForPage2);
+
+ ok(!persisted, "Second page should not be in the BFCache");
+
+ // Go back to the first page.
+ waitForPage1 = waitForMessage(bc);
+ bc.postMessage({ cmd: "back" });
+ let { persisted: fromBFCache, value: result } = await waitForPage1;
+
+ ok(fromBFCache, "Page came from BFCache");
+ is(result, expected, "Value wasn't cleared");
+
+ bc.postMessage({ cmd: "close" });
+
+ bc.close();
+
+ SimpleTest.finish();
+ }
+ </script>
+</head>
+<body onload="runTest();">
+<p id="display"></p>
+<div id="content" style="display: none"></div>
+<pre id="test"></pre>
+</body>
+</html>