summaryrefslogtreecommitdiffstats
path: root/toolkit/components/places/tests/bookmarks/test_675416.js
diff options
context:
space:
mode:
Diffstat (limited to 'toolkit/components/places/tests/bookmarks/test_675416.js')
-rw-r--r--toolkit/components/places/tests/bookmarks/test_675416.js56
1 files changed, 56 insertions, 0 deletions
diff --git a/toolkit/components/places/tests/bookmarks/test_675416.js b/toolkit/components/places/tests/bookmarks/test_675416.js
new file mode 100644
index 000000000..08b1c3620
--- /dev/null
+++ b/toolkit/components/places/tests/bookmarks/test_675416.js
@@ -0,0 +1,56 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+function run_test() {
+ /**
+ * Requests information to the service, so that bookmark's data is cached.
+ * @param aItemId
+ * Id of the bookmark to be cached.
+ */
+ function forceBookmarkCaching(aItemId) {
+ PlacesUtils.bookmarks.getFolderIdForItem(aItemId);
+ }
+
+ let observer = {
+ onBeginUpdateBatch: () => forceBookmarkCaching(itemId1),
+ onEndUpdateBatch: () => forceBookmarkCaching(itemId1),
+ onItemAdded: forceBookmarkCaching,
+ onItemChanged: forceBookmarkCaching,
+ onItemMoved: forceBookmarkCaching,
+ onItemRemoved: function(id) {
+ try {
+ forceBookmarkCaching(id);
+ do_throw("trying to fetch a removed bookmark should throw");
+ } catch (ex) {}
+ },
+ onItemVisited: forceBookmarkCaching,
+ QueryInterface: XPCOMUtils.generateQI([Ci.nsINavBookmarkObserver])
+ };
+ PlacesUtils.bookmarks.addObserver(observer, false);
+
+ let folderId1 = PlacesUtils.bookmarks
+ .createFolder(PlacesUtils.bookmarksMenuFolderId,
+ "Bookmarks",
+ PlacesUtils.bookmarks.DEFAULT_INDEX);
+ let itemId1 = PlacesUtils.bookmarks
+ .insertBookmark(folderId1,
+ NetUtil.newURI("http:/www.wired.com/wiredscience"),
+ PlacesUtils.bookmarks.DEFAULT_INDEX,
+ "Wired Science");
+
+ PlacesUtils.bookmarks.removeItem(folderId1);
+
+ let folderId2 = PlacesUtils.bookmarks
+ .createFolder(PlacesUtils.bookmarksMenuFolderId,
+ "Science",
+ PlacesUtils.bookmarks.DEFAULT_INDEX);
+ let folderId3 = PlacesUtils.bookmarks
+ .createFolder(folderId2,
+ "Blogs",
+ PlacesUtils.bookmarks.DEFAULT_INDEX);
+ // Check title is correctly reported.
+ do_check_eq(PlacesUtils.bookmarks.getItemTitle(folderId3), "Blogs");
+ do_check_eq(PlacesUtils.bookmarks.getItemTitle(folderId2), "Science");
+
+ PlacesUtils.bookmarks.removeObserver(observer, false);
+}