summaryrefslogtreecommitdiffstats
path: root/toolkit/components/places/tests/bookmarks/test_protectRoots.js
diff options
context:
space:
mode:
Diffstat (limited to 'toolkit/components/places/tests/bookmarks/test_protectRoots.js')
-rw-r--r--toolkit/components/places/tests/bookmarks/test_protectRoots.js37
1 files changed, 37 insertions, 0 deletions
diff --git a/toolkit/components/places/tests/bookmarks/test_protectRoots.js b/toolkit/components/places/tests/bookmarks/test_protectRoots.js
new file mode 100644
index 000000000..0a59f1653
--- /dev/null
+++ b/toolkit/components/places/tests/bookmarks/test_protectRoots.js
@@ -0,0 +1,37 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+function run_test()
+{
+ const ROOTS = [
+ PlacesUtils.bookmarksMenuFolderId,
+ PlacesUtils.toolbarFolderId,
+ PlacesUtils.unfiledBookmarksFolderId,
+ PlacesUtils.tagsFolderId,
+ PlacesUtils.placesRootId,
+ PlacesUtils.mobileFolderId,
+ ];
+
+ for (let root of ROOTS) {
+ do_check_true(PlacesUtils.isRootItem(root));
+
+ try {
+ PlacesUtils.bookmarks.removeItem(root);
+ do_throw("Trying to remove a root should throw");
+ } catch (ex) {}
+
+ try {
+ PlacesUtils.bookmarks.moveItem(root, PlacesUtils.placesRootId, 0);
+ do_throw("Trying to move a root should throw");
+ } catch (ex) {}
+
+ try {
+ PlacesUtils.bookmarks.removeFolderChildren(root);
+ if (root == PlacesUtils.placesRootId)
+ do_throw("Trying to remove children of the main root should throw");
+ } catch (ex) {
+ if (root != PlacesUtils.placesRootId)
+ do_throw("Trying to remove children of other roots should not throw");
+ }
+ }
+}