summaryrefslogtreecommitdiffstats
path: root/browser/components/sessionstore/test/browser_586068-reload.js
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 /browser/components/sessionstore/test/browser_586068-reload.js
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'browser/components/sessionstore/test/browser_586068-reload.js')
-rw-r--r--browser/components/sessionstore/test/browser_586068-reload.js118
1 files changed, 118 insertions, 0 deletions
diff --git a/browser/components/sessionstore/test/browser_586068-reload.js b/browser/components/sessionstore/test/browser_586068-reload.js
new file mode 100644
index 0000000000..b0b368824d
--- /dev/null
+++ b/browser/components/sessionstore/test/browser_586068-reload.js
@@ -0,0 +1,118 @@
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+const PREF_RESTORE_ON_DEMAND = "browser.sessionstore.restore_on_demand";
+
+add_task(async function test() {
+ Services.prefs.setBoolPref(PREF_RESTORE_ON_DEMAND, true);
+ registerCleanupFunction(function () {
+ Services.prefs.clearUserPref(PREF_RESTORE_ON_DEMAND);
+ });
+
+ let state = {
+ windows: [
+ {
+ tabs: [
+ {
+ entries: [
+ { url: "http://example.org/#1", triggeringPrincipal_base64 },
+ ],
+ extData: { uniq: r() },
+ },
+ {
+ entries: [
+ { url: "http://example.org/#2", triggeringPrincipal_base64 },
+ ],
+ extData: { uniq: r() },
+ },
+ {
+ entries: [
+ { url: "http://example.org/#3", triggeringPrincipal_base64 },
+ ],
+ extData: { uniq: r() },
+ },
+ {
+ entries: [
+ { url: "http://example.org/#4", triggeringPrincipal_base64 },
+ ],
+ extData: { uniq: r() },
+ },
+ {
+ entries: [
+ { url: "http://example.org/#5", triggeringPrincipal_base64 },
+ ],
+ extData: { uniq: r() },
+ },
+ {
+ entries: [
+ { url: "http://example.org/#6", triggeringPrincipal_base64 },
+ ],
+ extData: { uniq: r() },
+ },
+ {
+ entries: [
+ { url: "http://example.org/#7", triggeringPrincipal_base64 },
+ ],
+ extData: { uniq: r() },
+ },
+ {
+ entries: [
+ { url: "http://example.org/#8", triggeringPrincipal_base64 },
+ ],
+ extData: { uniq: r() },
+ },
+ {
+ entries: [
+ { url: "http://example.org/#9", triggeringPrincipal_base64 },
+ ],
+ extData: { uniq: r() },
+ },
+ ],
+ selected: 1,
+ },
+ ],
+ };
+
+ let loadCount = 0;
+ let promiseRestoringTabs = new Promise(resolve => {
+ gBrowser.tabContainer.addEventListener(
+ "SSTabRestored",
+ function onRestored(event) {
+ let tab = event.target;
+ let browser = tab.linkedBrowser;
+ let tabData = state.windows[0].tabs[loadCount++];
+
+ // double check that this tab was the right one
+ is(
+ browser.currentURI.spec,
+ tabData.entries[0].url,
+ "load " + loadCount + " - browser loaded correct url"
+ );
+ is(
+ ss.getCustomTabValue(tab, "uniq"),
+ tabData.extData.uniq,
+ "load " + loadCount + " - correct tab was restored"
+ );
+
+ if (loadCount == state.windows[0].tabs.length) {
+ gBrowser.tabContainer.removeEventListener(
+ "SSTabRestored",
+ onRestored
+ );
+ resolve();
+ } else {
+ // reload the next tab
+ gBrowser.browsers[loadCount].reload();
+ }
+ }
+ );
+ });
+
+ let backupState = ss.getBrowserState();
+ ss.setBrowserState(JSON.stringify(state));
+ await promiseRestoringTabs;
+
+ // Cleanup.
+ await promiseBrowserState(backupState);
+});