summaryrefslogtreecommitdiffstats
path: root/browser/components/preferences/tests/browser_homepages_use_bookmark.js
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/preferences/tests/browser_homepages_use_bookmark.js
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/preferences/tests/browser_homepages_use_bookmark.js')
-rw-r--r--browser/components/preferences/tests/browser_homepages_use_bookmark.js94
1 files changed, 94 insertions, 0 deletions
diff --git a/browser/components/preferences/tests/browser_homepages_use_bookmark.js b/browser/components/preferences/tests/browser_homepages_use_bookmark.js
new file mode 100644
index 0000000000..572783481d
--- /dev/null
+++ b/browser/components/preferences/tests/browser_homepages_use_bookmark.js
@@ -0,0 +1,94 @@
+/* Any copyright is dedicated to the Public Domain.
+ * http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"use strict";
+
+const TEST_URL1 = "http://example.com/1";
+const TEST_URL2 = "http://example.com/2";
+
+add_setup(async function () {
+ let oldHomepagePref = Services.prefs.getCharPref("browser.startup.homepage");
+
+ await openPreferencesViaOpenPreferencesAPI("paneHome", { leaveOpen: true });
+
+ Assert.equal(
+ gBrowser.currentURI.spec,
+ "about:preferences#home",
+ "#home should be in the URI for about:preferences"
+ );
+
+ registerCleanupFunction(async () => {
+ Services.prefs.setCharPref("browser.startup.homepage", oldHomepagePref);
+ BrowserTestUtils.removeTab(gBrowser.selectedTab);
+ await PlacesUtils.bookmarks.eraseEverything();
+ });
+});
+
+add_task(async function testSetHomepageFromBookmark() {
+ let bm = await PlacesUtils.bookmarks.insert({
+ parentGuid: PlacesUtils.bookmarks.menuGuid,
+ title: "TestHomepage",
+ url: TEST_URL1,
+ });
+
+ let doc = gBrowser.contentDocument;
+ // Select the custom URLs option.
+ doc.getElementById("homeMode").value = 2;
+
+ let promiseSubDialogLoaded = promiseLoadSubDialog(
+ "chrome://browser/content/preferences/dialogs/selectBookmark.xhtml"
+ );
+ doc.getElementById("useBookmarkBtn").click();
+
+ let dialog = await promiseSubDialogLoaded;
+ dialog.document.getElementById("bookmarks").selectItems([bm.guid]);
+ dialog.document
+ .getElementById("selectBookmarkDialog")
+ .getButton("accept")
+ .click();
+
+ await TestUtils.waitForCondition(() => HomePage.get() == TEST_URL1);
+
+ Assert.equal(
+ HomePage.get(),
+ TEST_URL1,
+ "Should have set the homepage to the same as the bookmark."
+ );
+});
+
+add_task(async function testSetHomepageFromTopLevelFolder() {
+ // Insert a second item into the menu folder
+ await PlacesUtils.bookmarks.insert({
+ parentGuid: PlacesUtils.bookmarks.menuGuid,
+ title: "TestHomepage",
+ url: TEST_URL2,
+ });
+
+ let doc = gBrowser.contentDocument;
+ // Select the custom URLs option.
+ doc.getElementById("homeMode").value = 2;
+
+ let promiseSubDialogLoaded = promiseLoadSubDialog(
+ "chrome://browser/content/preferences/dialogs/selectBookmark.xhtml"
+ );
+ doc.getElementById("useBookmarkBtn").click();
+
+ let dialog = await promiseSubDialogLoaded;
+ dialog.document
+ .getElementById("bookmarks")
+ .selectItems([PlacesUtils.bookmarks.menuGuid]);
+ dialog.document
+ .getElementById("selectBookmarkDialog")
+ .getButton("accept")
+ .click();
+
+ await TestUtils.waitForCondition(
+ () => HomePage.get() == `${TEST_URL1}|${TEST_URL2}`
+ );
+
+ Assert.equal(
+ HomePage.get(),
+ `${TEST_URL1}|${TEST_URL2}`,
+ "Should have set the homepage to the same as the bookmark."
+ );
+});