summaryrefslogtreecommitdiffstats
path: root/browser/components/sessionstore/test/browser_350525.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
commit43a97878ce14b72f0981164f87f2e35e14151312 (patch)
tree620249daf56c0258faa40cbdcf9cfba06de2a846 /browser/components/sessionstore/test/browser_350525.js
parentInitial commit. (diff)
downloadfirefox-43a97878ce14b72f0981164f87f2e35e14151312.tar.xz
firefox-43a97878ce14b72f0981164f87f2e35e14151312.zip
Adding upstream version 110.0.1.upstream/110.0.1upstream
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.js135
1 files changed, 135 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..812e5f1310
--- /dev/null
+++ b/browser/components/sessionstore/test/browser_350525.js
@@ -0,0 +1,135 @@
+"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);
+
+ /**
+ * getClosedTabCount, undoCloseTab
+ */
+
+ // get closed tab count
+ let count = ss.getClosedTabCount(window);
+ let max_tabs_undo = Services.prefs.getIntPref(
+ "browser.sessionstore.max_tabs_undo"
+ );
+ ok(
+ 0 <= count && count <= max_tabs_undo,
+ "getClosedTabCount 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 getClosedTabCount
+ 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);
+
+ // getClosedTabCount
+ let newcount = ss.getClosedTabCount(window);
+ ok(
+ newcount > count,
+ "after closing a tab, getClosedTabCount 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);
+});