mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
716 lines
26 KiB
JavaScript
716 lines
26 KiB
JavaScript
/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim:set ts=2 sw=2 sts=2 et: */
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
*
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at
|
|
* http://www.mozilla.org/MPL/
|
|
*
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
* for the specific language governing rights and limitations under the
|
|
* License.
|
|
*
|
|
* The Original Code is mozilla.org code.
|
|
*
|
|
* The Initial Developer of the Original Code is Google Inc.
|
|
* Portions created by the Initial Developer are Copyright (C) 2005
|
|
* the Initial Developer. All Rights Reserved.
|
|
*
|
|
* Contributor(s):
|
|
* Darin Fisher <darin@meer.net>
|
|
* Dietrich Ayala <dietrich@mozilla.com>
|
|
* Marco Bonardo <mak77@bonardo.net>
|
|
*
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
* the provisions above, a recipient may use your version of this file under
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
*
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
let bs = PlacesUtils.bookmarks;
|
|
let hs = PlacesUtils.history;
|
|
let anno = PlacesUtils.annotations;
|
|
|
|
|
|
let bookmarksObserver = {
|
|
onBeginUpdateBatch: function() {
|
|
this._beginUpdateBatch = true;
|
|
},
|
|
onEndUpdateBatch: function() {
|
|
this._endUpdateBatch = true;
|
|
},
|
|
onItemAdded: function(id, folder, index, itemType) {
|
|
this._itemAddedId = id;
|
|
this._itemAddedParent = folder;
|
|
this._itemAddedIndex = index;
|
|
},
|
|
onBeforeItemRemoved: function(){},
|
|
onItemRemoved: function(id, folder, index, itemType) {
|
|
this._itemRemovedId = id;
|
|
this._itemRemovedFolder = folder;
|
|
this._itemRemovedIndex = index;
|
|
},
|
|
onItemChanged: function(id, property, isAnnotationProperty, value,
|
|
lastModified, itemType) {
|
|
this._itemChangedId = id;
|
|
this._itemChangedProperty = property;
|
|
this._itemChanged_isAnnotationProperty = isAnnotationProperty;
|
|
this._itemChangedValue = value;
|
|
},
|
|
onItemVisited: function(id, visitID, time) {
|
|
this._itemVisitedId = id;
|
|
this._itemVisitedVistId = visitID;
|
|
this._itemVisitedTime = time;
|
|
},
|
|
onItemMoved: function(id, oldParent, oldIndex, newParent, newIndex,
|
|
itemType) {
|
|
this._itemMovedId = id
|
|
this._itemMovedOldParent = oldParent;
|
|
this._itemMovedOldIndex = oldIndex;
|
|
this._itemMovedNewParent = newParent;
|
|
this._itemMovedNewIndex = newIndex;
|
|
},
|
|
QueryInterface: XPCOMUtils.generateQI([
|
|
Ci.nsINavBookmarkObserver,
|
|
])
|
|
};
|
|
|
|
|
|
// Get bookmarks menu folder id.
|
|
let root = bs.bookmarksMenuFolder;
|
|
// Index at which items should begin.
|
|
let bmStartIndex = 0;
|
|
|
|
|
|
function run_test() {
|
|
bs.addObserver(bookmarksObserver, false);
|
|
|
|
// test special folders
|
|
do_check_true(bs.placesRoot > 0);
|
|
do_check_true(bs.bookmarksMenuFolder > 0);
|
|
do_check_true(bs.tagsFolder > 0);
|
|
do_check_true(bs.toolbarFolder > 0);
|
|
do_check_true(bs.unfiledBookmarksFolder > 0);
|
|
|
|
// test getFolderIdForItem() with bogus item id will throw
|
|
try {
|
|
let id = bs.getFolderIdForItem(0);
|
|
do_throw("getFolderIdForItem accepted bad input");
|
|
} catch(ex) {}
|
|
|
|
// test getFolderIdForItem() with bogus item id will throw
|
|
try {
|
|
let id = bs.getFolderIdForItem(-1);
|
|
do_throw("getFolderIdForItem accepted bad input");
|
|
} catch(ex) {}
|
|
|
|
// test root parentage
|
|
do_check_eq(bs.getFolderIdForItem(bs.bookmarksMenuFolder), bs.placesRoot);
|
|
do_check_eq(bs.getFolderIdForItem(bs.tagsFolder), bs.placesRoot);
|
|
do_check_eq(bs.getFolderIdForItem(bs.toolbarFolder), bs.placesRoot);
|
|
do_check_eq(bs.getFolderIdForItem(bs.unfiledBookmarksFolder), bs.placesRoot);
|
|
|
|
// create a folder to hold all the tests
|
|
// this makes the tests more tolerant of changes to default_places.html
|
|
let testRoot = bs.createFolder(root, "places bookmarks xpcshell tests",
|
|
bs.DEFAULT_INDEX);
|
|
do_check_eq(bookmarksObserver._itemAddedId, testRoot);
|
|
do_check_eq(bookmarksObserver._itemAddedParent, root);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, bmStartIndex);
|
|
let testStartIndex = 0;
|
|
|
|
// test getItemIndex for folders
|
|
do_check_eq(bs.getItemIndex(testRoot), bmStartIndex);
|
|
|
|
// test getItemType for folders
|
|
do_check_eq(bs.getItemType(testRoot), bs.TYPE_FOLDER);
|
|
|
|
// insert a bookmark
|
|
// the time before we insert, in microseconds
|
|
let beforeInsert = Date.now() * 1000;
|
|
do_check_true(beforeInsert > 0);
|
|
|
|
let newId = bs.insertBookmark(testRoot, uri("http://google.com/"),
|
|
bs.DEFAULT_INDEX, "");
|
|
do_check_eq(bookmarksObserver._itemAddedId, newId);
|
|
do_check_eq(bookmarksObserver._itemAddedParent, testRoot);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, testStartIndex);
|
|
do_check_eq(bs.getBookmarkURI(newId).spec, "http://google.com/");
|
|
|
|
let dateAdded = bs.getItemDateAdded(newId);
|
|
// dateAdded can equal beforeInsert
|
|
do_check_true(is_time_ordered(beforeInsert, dateAdded));
|
|
|
|
// after just inserting, modified should not be set
|
|
let lastModified = bs.getItemLastModified(newId);
|
|
do_check_eq(lastModified, dateAdded);
|
|
|
|
// The time before we set the title, in microseconds.
|
|
let beforeSetTitle = Date.now() * 1000;
|
|
do_check_true(beforeSetTitle >= beforeInsert);
|
|
|
|
// Workaround possible VM timers issues moving lastModified and dateAdded
|
|
// to the past.
|
|
bs.setItemLastModified(newId, --lastModified);
|
|
bs.setItemDateAdded(newId, --dateAdded);
|
|
|
|
// set bookmark title
|
|
bs.setItemTitle(newId, "Google");
|
|
do_check_eq(bookmarksObserver._itemChangedId, newId);
|
|
do_check_eq(bookmarksObserver._itemChangedProperty, "title");
|
|
do_check_eq(bookmarksObserver._itemChangedValue, "Google");
|
|
|
|
// check that dateAdded hasn't changed
|
|
let dateAdded2 = bs.getItemDateAdded(newId);
|
|
do_check_eq(dateAdded2, dateAdded);
|
|
|
|
// check lastModified after we set the title
|
|
let lastModified2 = bs.getItemLastModified(newId);
|
|
LOG("test setItemTitle");
|
|
LOG("dateAdded = " + dateAdded);
|
|
LOG("beforeSetTitle = " + beforeSetTitle);
|
|
LOG("lastModified = " + lastModified);
|
|
LOG("lastModified2 = " + lastModified2);
|
|
do_check_true(is_time_ordered(lastModified, lastModified2));
|
|
do_check_true(is_time_ordered(dateAdded, lastModified2));
|
|
|
|
// get item title
|
|
let title = bs.getItemTitle(newId);
|
|
do_check_eq(title, "Google");
|
|
|
|
// test getItemType for bookmarks
|
|
do_check_eq(bs.getItemType(newId), bs.TYPE_BOOKMARK);
|
|
|
|
// get item title bad input
|
|
try {
|
|
let title = bs.getItemTitle(-3);
|
|
do_throw("getItemTitle accepted bad input");
|
|
} catch(ex) {}
|
|
|
|
// get the folder that the bookmark is in
|
|
let folderId = bs.getFolderIdForItem(newId);
|
|
do_check_eq(folderId, testRoot);
|
|
|
|
// test getItemIndex for bookmarks
|
|
do_check_eq(bs.getItemIndex(newId), testStartIndex);
|
|
|
|
// create a folder at a specific index
|
|
let workFolder = bs.createFolder(testRoot, "Work", 0);
|
|
do_check_eq(bookmarksObserver._itemAddedId, workFolder);
|
|
do_check_eq(bookmarksObserver._itemAddedParent, testRoot);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, 0);
|
|
|
|
do_check_eq(bs.getItemTitle(workFolder), "Work");
|
|
bs.setItemTitle(workFolder, "Work #");
|
|
do_check_eq(bs.getItemTitle(workFolder), "Work #");
|
|
|
|
// add item into subfolder, specifying index
|
|
let newId2 = bs.insertBookmark(workFolder,
|
|
uri("http://developer.mozilla.org/"),
|
|
0, "");
|
|
do_check_eq(bookmarksObserver._itemAddedId, newId2);
|
|
do_check_eq(bookmarksObserver._itemAddedParent, workFolder);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, 0);
|
|
|
|
// change item
|
|
bs.setItemTitle(newId2, "DevMo");
|
|
do_check_eq(bookmarksObserver._itemChangedProperty, "title");
|
|
|
|
// insert item into subfolder
|
|
let newId3 = bs.insertBookmark(workFolder,
|
|
uri("http://msdn.microsoft.com/"),
|
|
bs.DEFAULT_INDEX, "");
|
|
do_check_eq(bookmarksObserver._itemAddedId, newId3);
|
|
do_check_eq(bookmarksObserver._itemAddedParent, workFolder);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, 1);
|
|
|
|
// change item
|
|
bs.setItemTitle(newId3, "MSDN");
|
|
do_check_eq(bookmarksObserver._itemChangedProperty, "title");
|
|
|
|
// remove item
|
|
bs.removeItem(newId2);
|
|
do_check_eq(bookmarksObserver._itemRemovedId, newId2);
|
|
do_check_eq(bookmarksObserver._itemRemovedFolder, workFolder);
|
|
do_check_eq(bookmarksObserver._itemRemovedIndex, 0);
|
|
|
|
// insert item into subfolder
|
|
let newId4 = bs.insertBookmark(workFolder,
|
|
uri("http://developer.mozilla.org/"),
|
|
bs.DEFAULT_INDEX, "");
|
|
do_check_eq(bookmarksObserver._itemAddedId, newId4);
|
|
do_check_eq(bookmarksObserver._itemAddedParent, workFolder);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, 1);
|
|
|
|
// create folder
|
|
let homeFolder = bs.createFolder(testRoot, "Home", bs.DEFAULT_INDEX);
|
|
do_check_eq(bookmarksObserver._itemAddedId, homeFolder);
|
|
do_check_eq(bookmarksObserver._itemAddedParent, testRoot);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, 2);
|
|
|
|
// insert item
|
|
let newId5 = bs.insertBookmark(homeFolder, uri("http://espn.com/"),
|
|
bs.DEFAULT_INDEX, "");
|
|
do_check_eq(bookmarksObserver._itemAddedId, newId5);
|
|
do_check_eq(bookmarksObserver._itemAddedParent, homeFolder);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, 0);
|
|
|
|
// change item
|
|
bs.setItemTitle(newId5, "ESPN");
|
|
do_check_eq(bookmarksObserver._itemChangedId, newId5);
|
|
do_check_eq(bookmarksObserver._itemChangedProperty, "title");
|
|
|
|
// insert query item
|
|
let uri6 = uri("place:domain=google.com&type="+
|
|
Ci.nsINavHistoryQueryOptions.RESULTS_AS_SITE_QUERY);
|
|
let newId6 = bs.insertBookmark(testRoot, uri6, bs.DEFAULT_INDEX, "");
|
|
do_check_eq(bookmarksObserver._itemAddedParent, testRoot);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, 3);
|
|
|
|
// change item
|
|
bs.setItemTitle(newId6, "Google Sites");
|
|
do_check_eq(bookmarksObserver._itemChangedProperty, "title");
|
|
|
|
// test getIdForItemAt
|
|
do_check_eq(bs.getIdForItemAt(testRoot, 0), workFolder);
|
|
// wrong parent, should return -1
|
|
do_check_eq(bs.getIdForItemAt(1337, 0), -1);
|
|
// wrong index, should return -1
|
|
do_check_eq(bs.getIdForItemAt(testRoot, 1337), -1);
|
|
// wrong parent and index, should return -1
|
|
do_check_eq(bs.getIdForItemAt(1337, 1337), -1);
|
|
|
|
// move folder, appending, to different folder
|
|
let oldParentCC = getChildCount(testRoot);
|
|
bs.moveItem(workFolder, homeFolder, bs.DEFAULT_INDEX);
|
|
do_check_eq(bookmarksObserver._itemMovedId, workFolder);
|
|
do_check_eq(bookmarksObserver._itemMovedOldParent, testRoot);
|
|
do_check_eq(bookmarksObserver._itemMovedOldIndex, 0);
|
|
do_check_eq(bookmarksObserver._itemMovedNewParent, homeFolder);
|
|
do_check_eq(bookmarksObserver._itemMovedNewIndex, 1);
|
|
|
|
// test that the new index is properly stored
|
|
do_check_eq(bs.getItemIndex(workFolder), 1);
|
|
do_check_eq(bs.getFolderIdForItem(workFolder), homeFolder);
|
|
|
|
// try to get index of the item from within the old parent folder
|
|
// check that it has been really removed from there
|
|
do_check_neq(bs.getIdForItemAt(testRoot, 0), workFolder);
|
|
// check the last item from within the old parent folder
|
|
do_check_neq(bs.getIdForItemAt(testRoot, -1), workFolder);
|
|
// check the index of the item within the new parent folder
|
|
do_check_eq(bs.getIdForItemAt(homeFolder, 1), workFolder);
|
|
// try to get index of the last item within the new parent folder
|
|
do_check_eq(bs.getIdForItemAt(homeFolder, -1), workFolder);
|
|
// XXX expose FolderCount, and check that the old parent has one less child?
|
|
do_check_eq(getChildCount(testRoot), oldParentCC-1);
|
|
|
|
// move item, appending, to different folder
|
|
bs.moveItem(newId5, testRoot, bs.DEFAULT_INDEX);
|
|
do_check_eq(bookmarksObserver._itemMovedId, newId5);
|
|
do_check_eq(bookmarksObserver._itemMovedOldParent, homeFolder);
|
|
do_check_eq(bookmarksObserver._itemMovedOldIndex, 0);
|
|
do_check_eq(bookmarksObserver._itemMovedNewParent, testRoot);
|
|
do_check_eq(bookmarksObserver._itemMovedNewIndex, 3);
|
|
|
|
// test get folder's index
|
|
let tmpFolder = bs.createFolder(testRoot, "tmp", 2);
|
|
do_check_eq(bs.getItemIndex(tmpFolder), 2);
|
|
|
|
// test setKeywordForBookmark
|
|
let kwTestItemId = bs.insertBookmark(testRoot, uri("http://keywordtest.com"),
|
|
bs.DEFAULT_INDEX, "");
|
|
try {
|
|
let dateAdded = bs.getItemDateAdded(kwTestItemId);
|
|
// after just inserting, modified should not be set
|
|
let lastModified = bs.getItemLastModified(kwTestItemId);
|
|
do_check_eq(lastModified, dateAdded);
|
|
|
|
// Workaround possible VM timers issues moving lastModified and dateAdded
|
|
// to the past.
|
|
bs.setItemLastModified(kwTestItemId, --lastModified);
|
|
bs.setItemDateAdded(kwTestItemId, --dateAdded);
|
|
|
|
bs.setKeywordForBookmark(kwTestItemId, "bar");
|
|
|
|
let lastModified2 = bs.getItemLastModified(kwTestItemId);
|
|
LOG("test setKeywordForBookmark");
|
|
LOG("dateAdded = " + dateAdded);
|
|
LOG("lastModified = " + lastModified);
|
|
LOG("lastModified2 = " + lastModified2);
|
|
do_check_true(is_time_ordered(lastModified, lastModified2));
|
|
do_check_true(is_time_ordered(dateAdded, lastModified2));
|
|
} catch(ex) {
|
|
do_throw("setKeywordForBookmark: " + ex);
|
|
}
|
|
|
|
let lastModified3 = bs.getItemLastModified(kwTestItemId);
|
|
// test getKeywordForBookmark
|
|
let k = bs.getKeywordForBookmark(kwTestItemId);
|
|
do_check_eq("bar", k);
|
|
|
|
// test getKeywordForURI
|
|
let k = bs.getKeywordForURI(uri("http://keywordtest.com/"));
|
|
do_check_eq("bar", k);
|
|
|
|
// test getURIForKeyword
|
|
let u = bs.getURIForKeyword("bar");
|
|
do_check_eq("http://keywordtest.com/", u.spec);
|
|
|
|
// test removeFolderChildren
|
|
// 1) add/remove each child type (bookmark, separator, folder)
|
|
let tmpFolder = bs.createFolder(testRoot, "removeFolderChildren",
|
|
bs.DEFAULT_INDEX);
|
|
bs.insertBookmark(tmpFolder, uri("http://foo9.com/"), bs.DEFAULT_INDEX, "");
|
|
bs.createFolder(tmpFolder, "subfolder", bs.DEFAULT_INDEX);
|
|
bs.insertSeparator(tmpFolder, bs.DEFAULT_INDEX);
|
|
// 2) confirm that folder has 3 children
|
|
let options = hs.getNewQueryOptions();
|
|
let query = hs.getNewQuery();
|
|
query.setFolders([tmpFolder], 1);
|
|
try {
|
|
let result = hs.executeQuery(query, options);
|
|
let rootNode = result.root;
|
|
rootNode.containerOpen = true;
|
|
do_check_eq(rootNode.childCount, 3);
|
|
rootNode.containerOpen = false;
|
|
} catch(ex) {
|
|
do_throw("test removeFolderChildren() - querying for children failed: " + ex);
|
|
}
|
|
// 3) remove all children
|
|
bs.removeFolderChildren(tmpFolder);
|
|
// 4) confirm that folder has 0 children
|
|
try {
|
|
result = hs.executeQuery(query, options);
|
|
let rootNode = result.root;
|
|
rootNode.containerOpen = true;
|
|
do_check_eq(rootNode.childCount, 0);
|
|
rootNode.containerOpen = false;
|
|
} catch(ex) {
|
|
do_throw("removeFolderChildren(): " + ex);
|
|
}
|
|
|
|
// XXX - test folderReadOnly
|
|
|
|
// test bookmark id in query output
|
|
try {
|
|
let options = hs.getNewQueryOptions();
|
|
let query = hs.getNewQuery();
|
|
query.setFolders([testRoot], 1);
|
|
let result = hs.executeQuery(query, options);
|
|
let rootNode = result.root;
|
|
rootNode.containerOpen = true;
|
|
let cc = rootNode.childCount;
|
|
LOG("bookmark itemId test: CC = " + cc);
|
|
do_check_true(cc > 0);
|
|
for (let i=0; i < cc; ++i) {
|
|
let node = rootNode.getChild(i);
|
|
if (node.type == node.RESULT_TYPE_FOLDER ||
|
|
node.type == node.RESULT_TYPE_URI ||
|
|
node.type == node.RESULT_TYPE_SEPARATOR ||
|
|
node.type == node.RESULT_TYPE_QUERY) {
|
|
do_check_true(node.itemId > 0);
|
|
}
|
|
else {
|
|
do_check_eq(node.itemId, -1);
|
|
}
|
|
}
|
|
rootNode.containerOpen = false;
|
|
}
|
|
catch(ex) {
|
|
do_throw("bookmarks query: " + ex);
|
|
}
|
|
|
|
// test that multiple bookmarks with same URI show up right in bookmark
|
|
// folder queries, todo: also to do for complex folder queries
|
|
try {
|
|
// test uri
|
|
let mURI = uri("http://multiple.uris.in.query");
|
|
|
|
let testFolder = bs.createFolder(testRoot, "test Folder", bs.DEFAULT_INDEX);
|
|
// add 2 bookmarks
|
|
bs.insertBookmark(testFolder, mURI, bs.DEFAULT_INDEX, "title 1");
|
|
bs.insertBookmark(testFolder, mURI, bs.DEFAULT_INDEX, "title 2");
|
|
|
|
// query
|
|
let options = hs.getNewQueryOptions();
|
|
let query = hs.getNewQuery();
|
|
query.setFolders([testFolder], 1);
|
|
let result = hs.executeQuery(query, options);
|
|
let rootNode = result.root;
|
|
rootNode.containerOpen = true;
|
|
let cc = rootNode.childCount;
|
|
do_check_eq(cc, 2);
|
|
do_check_eq(rootNode.getChild(0).title, "title 1");
|
|
do_check_eq(rootNode.getChild(1).title, "title 2");
|
|
rootNode.containerOpen = false;
|
|
}
|
|
catch(ex) {
|
|
do_throw("bookmarks query: " + ex);
|
|
}
|
|
|
|
// test change bookmark uri
|
|
let newId10 = bs.insertBookmark(testRoot, uri("http://foo10.com/"),
|
|
bs.DEFAULT_INDEX, "");
|
|
let dateAdded = bs.getItemDateAdded(newId10);
|
|
// after just inserting, modified should not be set
|
|
let lastModified = bs.getItemLastModified(newId10);
|
|
do_check_eq(lastModified, dateAdded);
|
|
|
|
// Workaround possible VM timers issues moving lastModified and dateAdded
|
|
// to the past.
|
|
bs.setItemLastModified(newId10, --lastModified);
|
|
bs.setItemDateAdded(newId10, --dateAdded);
|
|
|
|
bs.changeBookmarkURI(newId10, uri("http://foo11.com/"));
|
|
|
|
// check that lastModified is set after we change the bookmark uri
|
|
let lastModified2 = bs.getItemLastModified(newId10);
|
|
LOG("test changeBookmarkURI");
|
|
LOG("dateAdded = " + dateAdded);
|
|
LOG("lastModified = " + lastModified);
|
|
LOG("lastModified2 = " + lastModified2);
|
|
do_check_true(is_time_ordered(lastModified, lastModified2));
|
|
do_check_true(is_time_ordered(dateAdded, lastModified2));
|
|
|
|
do_check_eq(bookmarksObserver._itemChangedId, newId10);
|
|
do_check_eq(bookmarksObserver._itemChangedProperty, "uri");
|
|
do_check_eq(bookmarksObserver._itemChangedValue, "http://foo11.com/");
|
|
|
|
// test getBookmarkURI
|
|
let newId11 = bs.insertBookmark(testRoot, uri("http://foo11.com/"),
|
|
bs.DEFAULT_INDEX, "");
|
|
let bmURI = bs.getBookmarkURI(newId11);
|
|
do_check_eq("http://foo11.com/", bmURI.spec);
|
|
|
|
// test getBookmarkURI with non-bookmark items
|
|
try {
|
|
bs.getBookmarkURI(testRoot);
|
|
do_throw("getBookmarkURI() should throw for non-bookmark items!");
|
|
} catch(ex) {}
|
|
|
|
// test getItemIndex
|
|
let newId12 = bs.insertBookmark(testRoot, uri("http://foo11.com/"), 1, "");
|
|
let bmIndex = bs.getItemIndex(newId12);
|
|
do_check_eq(1, bmIndex);
|
|
|
|
// insert a bookmark with title ZZZXXXYYY and then search for it.
|
|
// this test confirms that we can find bookmarks that we haven't visited
|
|
// (which are "hidden") and that we can find by title.
|
|
// see bug #369887 for more details
|
|
let newId13 = bs.insertBookmark(testRoot, uri("http://foobarcheese.com/"),
|
|
bs.DEFAULT_INDEX, "");
|
|
do_check_eq(bookmarksObserver._itemAddedId, newId13);
|
|
do_check_eq(bookmarksObserver._itemAddedParent, testRoot);
|
|
do_check_eq(bookmarksObserver._itemAddedIndex, 11);
|
|
|
|
// set bookmark title
|
|
bs.setItemTitle(newId13, "ZZZXXXYYY");
|
|
do_check_eq(bookmarksObserver._itemChangedId, newId13);
|
|
do_check_eq(bookmarksObserver._itemChangedProperty, "title");
|
|
do_check_eq(bookmarksObserver._itemChangedValue, "ZZZXXXYYY");
|
|
|
|
// check if setting an item annotation triggers onItemChanged
|
|
bookmarksObserver._itemChangedId = -1;
|
|
anno.setItemAnnotation(newId3, "test-annotation", "foo", 0, 0);
|
|
do_check_eq(bookmarksObserver._itemChangedId, newId3);
|
|
do_check_eq(bookmarksObserver._itemChangedProperty, "test-annotation");
|
|
do_check_true(bookmarksObserver._itemChanged_isAnnotationProperty);
|
|
do_check_eq(bookmarksObserver._itemChangedValue, "");
|
|
|
|
// test search on bookmark title ZZZXXXYYY
|
|
try {
|
|
let options = hs.getNewQueryOptions();
|
|
options.excludeQueries = 1;
|
|
options.queryType = Ci.nsINavHistoryQueryOptions.QUERY_TYPE_BOOKMARKS;
|
|
let query = hs.getNewQuery();
|
|
query.searchTerms = "ZZZXXXYYY";
|
|
let result = hs.executeQuery(query, options);
|
|
let rootNode = result.root;
|
|
rootNode.containerOpen = true;
|
|
let cc = rootNode.childCount;
|
|
do_check_eq(cc, 1);
|
|
let node = rootNode.getChild(0);
|
|
do_check_eq(node.title, "ZZZXXXYYY");
|
|
do_check_true(node.itemId > 0);
|
|
rootNode.containerOpen = false;
|
|
}
|
|
catch(ex) {
|
|
do_throw("bookmarks query: " + ex);
|
|
}
|
|
|
|
// test dateAdded and lastModified properties
|
|
// for a search query
|
|
try {
|
|
let options = hs.getNewQueryOptions();
|
|
options.excludeQueries = 1;
|
|
options.queryType = Ci.nsINavHistoryQueryOptions.QUERY_TYPE_BOOKMARKS;
|
|
let query = hs.getNewQuery();
|
|
query.searchTerms = "ZZZXXXYYY";
|
|
let result = hs.executeQuery(query, options);
|
|
let rootNode = result.root;
|
|
rootNode.containerOpen = true;
|
|
let cc = rootNode.childCount;
|
|
do_check_eq(cc, 1);
|
|
let node = rootNode.getChild(0);
|
|
|
|
do_check_eq(typeof node.dateAdded, "number");
|
|
do_check_true(node.dateAdded > 0);
|
|
|
|
do_check_eq(typeof node.lastModified, "number");
|
|
do_check_true(node.lastModified > 0);
|
|
|
|
rootNode.containerOpen = false;
|
|
}
|
|
catch(ex) {
|
|
do_throw("bookmarks query: " + ex);
|
|
}
|
|
|
|
// test dateAdded and lastModified properties
|
|
// for a folder query
|
|
try {
|
|
let options = hs.getNewQueryOptions();
|
|
let query = hs.getNewQuery();
|
|
query.setFolders([testRoot], 1);
|
|
let result = hs.executeQuery(query, options);
|
|
let rootNode = result.root;
|
|
rootNode.containerOpen = true;
|
|
let cc = rootNode.childCount;
|
|
do_check_true(cc > 0);
|
|
for (let i = 0; i < cc; i++) {
|
|
let node = rootNode.getChild(i);
|
|
|
|
if (node.type == node.RESULT_TYPE_URI) {
|
|
do_check_eq(typeof node.dateAdded, "number");
|
|
do_check_true(node.dateAdded > 0);
|
|
|
|
do_check_eq(typeof node.lastModified, "number");
|
|
do_check_true(node.lastModified > 0);
|
|
break;
|
|
}
|
|
}
|
|
rootNode.containerOpen = false;
|
|
}
|
|
catch(ex) {
|
|
do_throw("bookmarks query: " + ex);
|
|
}
|
|
|
|
// check setItemLastModified() and setItemDateAdded()
|
|
let newId14 = bs.insertBookmark(testRoot, uri("http://bar.tld/"),
|
|
bs.DEFAULT_INDEX, "");
|
|
let dateAdded = bs.getItemDateAdded(newId14);
|
|
let lastModified = bs.getItemLastModified(newId14);
|
|
do_check_eq(lastModified, dateAdded);
|
|
bs.setItemLastModified(newId14, 1234);
|
|
let fakeLastModified = bs.getItemLastModified(newId14);
|
|
do_check_eq(fakeLastModified, 1234);
|
|
bs.setItemDateAdded(newId14, 4321);
|
|
let fakeDateAdded = bs.getItemDateAdded(newId14);
|
|
do_check_eq(fakeDateAdded, 4321);
|
|
|
|
// ensure that removing an item removes its annotations
|
|
do_check_true(anno.itemHasAnnotation(newId3, "test-annotation"));
|
|
bs.removeItem(newId3);
|
|
do_check_false(anno.itemHasAnnotation(newId3, "test-annotation"));
|
|
|
|
// bug 378820
|
|
let uri1 = uri("http://foo.tld/a");
|
|
bs.insertBookmark(testRoot, uri1, bs.DEFAULT_INDEX, "");
|
|
hs.addVisit(uri1, Date.now() * 1000, null, hs.TRANSITION_TYPED, false, 0);
|
|
|
|
testSimpleFolderResult();
|
|
}
|
|
|
|
function testSimpleFolderResult() {
|
|
// the time before we create a folder, in microseconds
|
|
// Workaround possible VM timers issues subtracting 1us.
|
|
let beforeCreate = Date.now() * 1000 - 1;
|
|
do_check_true(beforeCreate > 0);
|
|
|
|
// create a folder
|
|
let parent = bs.createFolder(root, "test", bs.DEFAULT_INDEX);
|
|
|
|
let dateCreated = bs.getItemDateAdded(parent);
|
|
LOG("check that the folder was created with a valid dateAdded");
|
|
LOG("beforeCreate = " + beforeCreate);
|
|
LOG("dateCreated = " + dateCreated);
|
|
do_check_true(is_time_ordered(beforeCreate, dateCreated));
|
|
|
|
// the time before we insert, in microseconds
|
|
// Workaround possible VM timers issues subtracting 1ms.
|
|
let beforeInsert = Date.now() * 1000 - 1;
|
|
do_check_true(beforeInsert > 0);
|
|
|
|
// insert a separator
|
|
let sep = bs.insertSeparator(parent, bs.DEFAULT_INDEX);
|
|
|
|
let dateAdded = bs.getItemDateAdded(sep);
|
|
LOG("check that the separator was created with a valid dateAdded");
|
|
LOG("beforeInsert = " + beforeInsert);
|
|
LOG("dateAdded = " + dateAdded);
|
|
do_check_true(is_time_ordered(beforeInsert, dateAdded));
|
|
|
|
// re-set item title separately so can test nodes' last modified
|
|
let item = bs.insertBookmark(parent, uri("about:blank"),
|
|
bs.DEFAULT_INDEX, "");
|
|
bs.setItemTitle(item, "test bookmark");
|
|
|
|
// see above
|
|
let folder = bs.createFolder(parent, "test folder", bs.DEFAULT_INDEX);
|
|
bs.setItemTitle(folder, "test folder");
|
|
|
|
let options = hs.getNewQueryOptions();
|
|
let query = hs.getNewQuery();
|
|
query.setFolders([parent], 1);
|
|
let result = hs.executeQuery(query, options);
|
|
let rootNode = result.root;
|
|
rootNode.containerOpen = true;
|
|
do_check_eq(rootNode.childCount, 3);
|
|
|
|
let node = rootNode.getChild(0);
|
|
do_check_true(node.dateAdded > 0);
|
|
do_check_eq(node.lastModified, node.dateAdded);
|
|
do_check_eq(node.itemId, sep);
|
|
do_check_eq(node.title, "");
|
|
node = rootNode.getChild(1);
|
|
do_check_eq(node.itemId, item);
|
|
do_check_true(node.dateAdded > 0);
|
|
do_check_true(node.lastModified > 0);
|
|
do_check_eq(node.title, "test bookmark");
|
|
node = rootNode.getChild(2);
|
|
do_check_eq(node.itemId, folder);
|
|
do_check_eq(node.title, "test folder");
|
|
do_check_true(node.dateAdded > 0);
|
|
do_check_true(node.lastModified > 0);
|
|
|
|
rootNode.containerOpen = false;
|
|
}
|
|
|
|
function getChildCount(aFolderId) {
|
|
let cc = -1;
|
|
try {
|
|
let options = hs.getNewQueryOptions();
|
|
let query = hs.getNewQuery();
|
|
query.setFolders([aFolderId], 1);
|
|
let result = hs.executeQuery(query, options);
|
|
let rootNode = result.root;
|
|
rootNode.containerOpen = true;
|
|
cc = rootNode.childCount;
|
|
rootNode.containerOpen = false;
|
|
} catch(ex) {
|
|
do_throw("getChildCount failed: " + ex);
|
|
}
|
|
return cc;
|
|
}
|