summaryrefslogtreecommitdiffstats
path: root/toolkit/components/places/tests/unit/test_browserhistory.js
diff options
context:
space:
mode:
authorMatt A. Tobin <mattatobin@localhost.localdomain>2018-02-02 04:16:08 -0500
committerMatt A. Tobin <mattatobin@localhost.localdomain>2018-02-02 04:16:08 -0500
commit5f8de423f190bbb79a62f804151bc24824fa32d8 (patch)
tree10027f336435511475e392454359edea8e25895d /toolkit/components/places/tests/unit/test_browserhistory.js
parent49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff)
downloadUXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip
Add m-esr52 at 52.6.0
Diffstat (limited to 'toolkit/components/places/tests/unit/test_browserhistory.js')
-rw-r--r--toolkit/components/places/tests/unit/test_browserhistory.js129
1 files changed, 129 insertions, 0 deletions
diff --git a/toolkit/components/places/tests/unit/test_browserhistory.js b/toolkit/components/places/tests/unit/test_browserhistory.js
new file mode 100644
index 000000000..5f88c26e3
--- /dev/null
+++ b/toolkit/components/places/tests/unit/test_browserhistory.js
@@ -0,0 +1,129 @@
+/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
+/* vim:set ts=2 sw=2 sts=2 et: */
+/* 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 TEST_URI = NetUtil.newURI("http://mozilla.com/");
+const TEST_SUBDOMAIN_URI = NetUtil.newURI("http://foobar.mozilla.com/");
+
+add_task(function* test_addPage() {
+ yield PlacesTestUtils.addVisits(TEST_URI);
+ do_check_eq(1, PlacesUtils.history.hasHistoryEntries);
+});
+
+add_task(function* test_removePage() {
+ PlacesUtils.bhistory.removePage(TEST_URI);
+ do_check_eq(0, PlacesUtils.history.hasHistoryEntries);
+});
+
+add_task(function* test_removePages() {
+ let pages = [];
+ for (let i = 0; i < 8; i++) {
+ pages.push(NetUtil.newURI(TEST_URI.spec + i));
+ }
+
+ yield PlacesTestUtils.addVisits(pages.map(uri => ({ uri: uri })));
+ // Bookmarked item should not be removed from moz_places.
+ const ANNO_INDEX = 1;
+ const ANNO_NAME = "testAnno";
+ const ANNO_VALUE = "foo";
+ const BOOKMARK_INDEX = 2;
+ PlacesUtils.annotations.setPageAnnotation(pages[ANNO_INDEX],
+ ANNO_NAME, ANNO_VALUE, 0,
+ Ci.nsIAnnotationService.EXPIRE_NEVER);
+ PlacesUtils.bookmarks.insertBookmark(PlacesUtils.unfiledBookmarksFolderId,
+ pages[BOOKMARK_INDEX],
+ PlacesUtils.bookmarks.DEFAULT_INDEX,
+ "test bookmark");
+ PlacesUtils.annotations.setPageAnnotation(pages[BOOKMARK_INDEX],
+ ANNO_NAME, ANNO_VALUE, 0,
+ Ci.nsIAnnotationService.EXPIRE_NEVER);
+
+ PlacesUtils.bhistory.removePages(pages, pages.length);
+ do_check_eq(0, PlacesUtils.history.hasHistoryEntries);
+
+ // Check that the bookmark and its annotation still exist.
+ do_check_true(PlacesUtils.bookmarks.getIdForItemAt(PlacesUtils.unfiledBookmarksFolderId, 0) > 0);
+ do_check_eq(PlacesUtils.annotations.getPageAnnotation(pages[BOOKMARK_INDEX], ANNO_NAME),
+ ANNO_VALUE);
+
+ // Check the annotation on the non-bookmarked page does not exist anymore.
+ try {
+ PlacesUtils.annotations.getPageAnnotation(pages[ANNO_INDEX], ANNO_NAME);
+ do_throw("did not expire expire_never anno on a not bookmarked item");
+ } catch (ex) {}
+
+ // Cleanup.
+ PlacesUtils.bookmarks.removeFolderChildren(PlacesUtils.unfiledBookmarksFolderId);
+ yield PlacesTestUtils.clearHistory();
+});
+
+add_task(function* test_removePagesByTimeframe() {
+ let visits = [];
+ let startDate = (Date.now() - 10000) * 1000;
+ for (let i = 0; i < 10; i++) {
+ visits.push({
+ uri: NetUtil.newURI(TEST_URI.spec + i),
+ visitDate: startDate + i * 1000
+ });
+ }
+
+ yield PlacesTestUtils.addVisits(visits);
+
+ // Delete all pages except the first and the last.
+ PlacesUtils.bhistory.removePagesByTimeframe(startDate + 1000, startDate + 8000);
+
+ // Check that we have removed the correct pages.
+ for (let i = 0; i < 10; i++) {
+ do_check_eq(page_in_database(NetUtil.newURI(TEST_URI.spec + i)) == 0,
+ i > 0 && i < 9);
+ }
+
+ // Clear remaining items and check that all pages have been removed.
+ PlacesUtils.bhistory.removePagesByTimeframe(startDate, startDate + 9000);
+ do_check_eq(0, PlacesUtils.history.hasHistoryEntries);
+});
+
+add_task(function* test_removePagesFromHost() {
+ yield PlacesTestUtils.addVisits(TEST_URI);
+ PlacesUtils.bhistory.removePagesFromHost("mozilla.com", true);
+ do_check_eq(0, PlacesUtils.history.hasHistoryEntries);
+});
+
+add_task(function* test_removePagesFromHost_keepSubdomains() {
+ yield PlacesTestUtils.addVisits([{ uri: TEST_URI }, { uri: TEST_SUBDOMAIN_URI }]);
+ PlacesUtils.bhistory.removePagesFromHost("mozilla.com", false);
+ do_check_eq(1, PlacesUtils.history.hasHistoryEntries);
+});
+
+add_task(function* test_history_clear() {
+ yield PlacesTestUtils.clearHistory();
+ do_check_eq(0, PlacesUtils.history.hasHistoryEntries);
+});
+
+add_task(function* test_getObservers() {
+ // Ensure that getObservers() invalidates the hasHistoryEntries cache.
+ yield PlacesTestUtils.addVisits(TEST_URI);
+ do_check_eq(1, PlacesUtils.history.hasHistoryEntries);
+ // This is just for testing purposes, never do it.
+ return new Promise((resolve, reject) => {
+ DBConn().executeSimpleSQLAsync("DELETE FROM moz_historyvisits", {
+ handleError: function(error) {
+ reject(error);
+ },
+ handleResult: function(result) {
+ },
+ handleCompletion: function(result) {
+ // Just invoking getObservers should be enough to invalidate the cache.
+ PlacesUtils.history.getObservers();
+ do_check_eq(0, PlacesUtils.history.hasHistoryEntries);
+ resolve();
+ }
+ });
+ });
+});
+
+function run_test() {
+ run_next_test();
+}