summaryrefslogtreecommitdiffstats
path: root/browser/components/sessionstore/test/browser_350525.js
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 /browser/components/sessionstore/test/browser_350525.js
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 'browser/components/sessionstore/test/browser_350525.js')
-rw-r--r--browser/components/sessionstore/test/browser_350525.js136
1 files changed, 136 insertions, 0 deletions
diff --git a/browser/components/sessionstore/test/browser_350525.js b/browser/components/sessionstore/test/browser_350525.js
new file mode 100644
index 0000000000..ca577bf093
--- /dev/null
+++ b/browser/components/sessionstore/test/browser_350525.js
@@ -0,0 +1,136 @@
+"use strict";
+
+add_setup(async function () {
+ await SpecialPowers.pushPrefEnv({
+ set: [["dom.ipc.processCount", 1]],
+ });
+});
+
+add_task(async function () {
+ /** Test for Bug 350525 **/
+
+ function test(aLambda) {
+ try {
+ return aLambda() || true;
+ } catch (ex) {}
+ return false;
+ }
+
+ /**
+ * setCustomWindowValue, et al.
+ */
+ let key = "Unique name: " + Date.now();
+ let value = "Unique value: " + Math.random();
+
+ // test adding
+ ok(
+ test(() => ss.setCustomWindowValue(window, key, value)),
+ "set a window value"
+ );
+
+ // test retrieving
+ is(
+ ss.getCustomWindowValue(window, key),
+ value,
+ "stored window value matches original"
+ );
+
+ // test deleting
+ ok(
+ test(() => ss.deleteCustomWindowValue(window, key)),
+ "delete the window value"
+ );
+
+ // value should not exist post-delete
+ is(ss.getCustomWindowValue(window, key), "", "window value was deleted");
+
+ // test deleting a non-existent value
+ ok(
+ test(() => ss.deleteCustomWindowValue(window, key)),
+ "delete non-existent window value"
+ );
+
+ /**
+ * setCustomTabValue, et al.
+ */
+ key = "Unique name: " + Math.random();
+ value = "Unique value: " + Date.now();
+ let tab = BrowserTestUtils.addTab(gBrowser);
+ tab.linkedBrowser.stop();
+
+ // test adding
+ ok(
+ test(() => ss.setCustomTabValue(tab, key, value)),
+ "store a tab value"
+ );
+
+ // test retrieving
+ is(ss.getCustomTabValue(tab, key), value, "stored tab value match original");
+
+ // test deleting
+ ok(
+ test(() => ss.deleteCustomTabValue(tab, key)),
+ "delete the tab value"
+ );
+
+ // value should not exist post-delete
+ is(ss.getCustomTabValue(tab, key), "", "tab value was deleted");
+
+ // test deleting a non-existent value
+ ok(
+ test(() => ss.deleteCustomTabValue(tab, key)),
+ "delete non-existent tab value"
+ );
+
+ // clean up
+ await promiseRemoveTabAndSessionState(tab);
+
+ /**
+ * getClosedTabCountForWindow, undoCloseTab
+ */
+
+ // get closed tab count
+ let count = ss.getClosedTabCountForWindow(window);
+ let max_tabs_undo = Services.prefs.getIntPref(
+ "browser.sessionstore.max_tabs_undo"
+ );
+ ok(
+ 0 <= count && count <= max_tabs_undo,
+ "getClosedTabCountForWindow returns zero or at most max_tabs_undo"
+ );
+
+ // create a new tab
+ let testURL = "about:mozilla";
+ tab = BrowserTestUtils.addTab(gBrowser, testURL);
+ await promiseBrowserLoaded(tab.linkedBrowser);
+
+ // make sure that the next closed tab will increase getClosedTabCountForWindow
+ Services.prefs.setIntPref(
+ "browser.sessionstore.max_tabs_undo",
+ max_tabs_undo + 1
+ );
+ registerCleanupFunction(() =>
+ Services.prefs.clearUserPref("browser.sessionstore.max_tabs_undo")
+ );
+
+ // remove tab
+ await promiseRemoveTabAndSessionState(tab);
+
+ // getClosedTabCountForWindow
+ let newcount = ss.getClosedTabCountForWindow(window);
+ Assert.greater(
+ newcount,
+ count,
+ "after closing a tab, getClosedTabCountForWindow has been incremented"
+ );
+
+ // undoCloseTab
+ tab = test(() => ss.undoCloseTab(window, 0));
+ ok(tab, "undoCloseTab doesn't throw");
+
+ await promiseTabRestored(tab);
+ is(tab.linkedBrowser.currentURI.spec, testURL, "correct tab was reopened");
+
+ // clean up
+ gBrowser.removeTab(tab);
+});