2008-02-27 10:14:13 -08:00
|
|
|
/* -*- 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 Bug 384370 code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Mozilla Corp.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 2008
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Dietrich Ayala <dietrich@mozilla.com>
|
|
|
|
*
|
|
|
|
* 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 ***** */
|
|
|
|
|
2009-02-09 10:16:02 -08:00
|
|
|
// The following components need to be initialized to perform tests without
|
|
|
|
// asserting in debug builds (Bug 448804).
|
|
|
|
Cc["@mozilla.org/browser/livemark-service;2"].getService(Ci.nsILivemarkService);
|
|
|
|
Cc["@mozilla.org/feed-processor;1"].createInstance(Ci.nsIFeedProcessor);
|
|
|
|
|
2008-03-13 12:25:49 -07:00
|
|
|
const LOAD_IN_SIDEBAR_ANNO = "bookmarkProperties/loadInSidebar";
|
|
|
|
const DESCRIPTION_ANNO = "bookmarkProperties/description";
|
|
|
|
const POST_DATA_ANNO = "bookmarkProperties/POSTData";
|
|
|
|
|
|
|
|
Components.utils.import("resource://gre/modules/utils.js");
|
|
|
|
do_check_eq(typeof PlacesUtils, "object");
|
|
|
|
|
|
|
|
// main
|
2008-02-27 10:14:13 -08:00
|
|
|
function run_test() {
|
2008-03-13 12:25:49 -07:00
|
|
|
/*
|
|
|
|
HTML+FEATURES SUMMARY:
|
|
|
|
- import legacy bookmarks
|
|
|
|
- export as json, import, test (tests integrity of html > json)
|
|
|
|
- export as html, import, test (tests integrity of json > html)
|
|
|
|
|
|
|
|
BACKUP/RESTORE SUMMARY:
|
|
|
|
- create a bookmark in each root
|
|
|
|
- tag multiple URIs with multiple tags
|
|
|
|
- export as json, import, test
|
|
|
|
*/
|
|
|
|
|
|
|
|
// get places import/export service
|
|
|
|
var importer = Cc["@mozilla.org/browser/places/import-export-service;1"].getService(Ci.nsIPlacesImportExportService);
|
|
|
|
|
|
|
|
// avoid creating the places smart folder during tests
|
|
|
|
Cc["@mozilla.org/preferences-service;1"].getService(Ci.nsIPrefBranch).
|
2008-04-08 11:42:53 -07:00
|
|
|
setIntPref("browser.places.smartBookmarksVersion", -1);
|
2008-03-13 12:25:49 -07:00
|
|
|
|
|
|
|
// file pointer to legacy bookmarks file
|
2009-03-21 08:20:00 -07:00
|
|
|
//var bookmarksFileOld = do_get_file("bookmarks.large.html");
|
|
|
|
var bookmarksFileOld = do_get_file("bookmarks.preplaces.html");
|
2008-03-13 12:25:49 -07:00
|
|
|
// file pointer to a new places-exported json file
|
|
|
|
var jsonFile = dirSvc.get("ProfD", Ci.nsILocalFile);
|
|
|
|
jsonFile.append("bookmarks.exported.json");
|
|
|
|
|
|
|
|
// create bookmarks.exported.json
|
|
|
|
if (jsonFile.exists())
|
|
|
|
jsonFile.remove(false);
|
|
|
|
jsonFile.create(Ci.nsILocalFile.NORMAL_FILE_TYPE, 0600);
|
|
|
|
if (!jsonFile.exists())
|
|
|
|
do_throw("couldn't create file: bookmarks.exported.json");
|
|
|
|
|
|
|
|
// Test importing a pre-Places canonical bookmarks file.
|
|
|
|
// 1. import bookmarks.preplaces.html
|
|
|
|
// 2. run the test-suite
|
|
|
|
// Note: we do not empty the db before this import to catch bugs like 380999
|
|
|
|
try {
|
|
|
|
importer.importHTMLFromFile(bookmarksFileOld, true);
|
|
|
|
} catch(ex) { do_throw("couldn't import legacy bookmarks file: " + ex); }
|
|
|
|
populate();
|
|
|
|
validate();
|
|
|
|
|
|
|
|
// Test exporting a Places canonical json file.
|
|
|
|
// 1. export to bookmarks.exported.json
|
|
|
|
// 2. empty bookmarks db
|
|
|
|
// 3. import bookmarks.exported.json
|
|
|
|
// 4. run the test-suite
|
|
|
|
try {
|
2009-09-29 03:44:18 -07:00
|
|
|
PlacesUtils.backups.saveBookmarksToJSONFile(jsonFile);
|
2008-03-13 12:25:49 -07:00
|
|
|
} catch(ex) { do_throw("couldn't export to file: " + ex); }
|
|
|
|
LOG("exported json");
|
|
|
|
try {
|
2009-10-06 06:47:58 -07:00
|
|
|
PlacesUtils.restoreBookmarksFromJSONFile(jsonFile);
|
2008-03-13 12:25:49 -07:00
|
|
|
} catch(ex) { do_throw("couldn't import the exported file: " + ex); }
|
|
|
|
LOG("imported json");
|
|
|
|
validate();
|
|
|
|
LOG("validated import");
|
|
|
|
}
|
|
|
|
|
|
|
|
var tagData = [
|
|
|
|
{ uri: uri("http://slint.us"), tags: ["indie", "kentucky", "music"] },
|
|
|
|
{ uri: uri("http://en.wikipedia.org/wiki/Diplodocus"), tags: ["dinosaur", "dj", "rad word"] }
|
|
|
|
];
|
|
|
|
|
|
|
|
var bookmarkData = [
|
|
|
|
{ uri: uri("http://slint.us"), title: "indie, kentucky, music" },
|
|
|
|
{ uri: uri("http://en.wikipedia.org/wiki/Diplodocus"), title: "dinosaur, dj, rad word" }
|
|
|
|
];
|
|
|
|
|
|
|
|
/*
|
|
|
|
populate data in each folder
|
|
|
|
(menu is populated via the html import)
|
|
|
|
*/
|
|
|
|
function populate() {
|
|
|
|
// add tags
|
|
|
|
for each(let {uri: u, tags: t} in tagData)
|
|
|
|
PlacesUtils.tagging.tagURI(u, t);
|
|
|
|
|
|
|
|
// add unfiled bookmarks
|
|
|
|
for each(let {uri: u, title: t} in bookmarkData) {
|
|
|
|
PlacesUtils.bookmarks.insertBookmark(PlacesUtils.bookmarks.unfiledBookmarksFolder,
|
|
|
|
u, PlacesUtils.bookmarks.DEFAULT_INDEX, t);
|
|
|
|
}
|
|
|
|
|
|
|
|
// add to the toolbar
|
|
|
|
for each(let {uri: u, title: t} in bookmarkData) {
|
|
|
|
PlacesUtils.bookmarks.insertBookmark(PlacesUtils.bookmarks.toolbarFolder,
|
|
|
|
u, PlacesUtils.bookmarks.DEFAULT_INDEX, t);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function validate() {
|
|
|
|
testCanonicalBookmarks(PlacesUtils.bookmarks.bookmarksMenuFolder);
|
|
|
|
testToolbarFolder();
|
|
|
|
testUnfiledBookmarks();
|
|
|
|
testTags();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Tests a bookmarks datastore that has a set of bookmarks, etc
|
|
|
|
// that flex each supported field and feature.
|
|
|
|
function testCanonicalBookmarks() {
|
|
|
|
// query to see if the deleted folder and items have been imported
|
|
|
|
var query = PlacesUtils.history.getNewQuery();
|
|
|
|
query.setFolders([PlacesUtils.bookmarks.bookmarksMenuFolder], 1);
|
|
|
|
var result = PlacesUtils.history.executeQuery(query, PlacesUtils.history.getNewQueryOptions());
|
|
|
|
var rootNode = result.root;
|
|
|
|
rootNode.containerOpen = true;
|
|
|
|
|
|
|
|
// 6-2: the toolbar contents are imported to the places-toolbar folder,
|
|
|
|
// the separator above it is removed.
|
|
|
|
do_check_eq(rootNode.childCount, 4);
|
|
|
|
|
|
|
|
// get test folder
|
|
|
|
var testFolder = rootNode.getChild(3);
|
|
|
|
do_check_eq(testFolder.type, testFolder.RESULT_TYPE_FOLDER);
|
|
|
|
do_check_eq(testFolder.title, "test");
|
|
|
|
|
|
|
|
/*
|
|
|
|
// add date
|
|
|
|
do_check_eq(PlacesUtils.bookmarks.getItemDateAdded(testFolder.itemId)/1000000, 1177541020);
|
|
|
|
// last modified
|
|
|
|
do_check_eq(PlacesUtils.bookmarks.getItemLastModified(testFolder.itemId)/1000000, 1177541050);
|
|
|
|
*/
|
|
|
|
|
|
|
|
testFolder = testFolder.QueryInterface(Ci.nsINavHistoryQueryResultNode);
|
|
|
|
do_check_eq(testFolder.hasChildren, true);
|
|
|
|
// folder description
|
|
|
|
do_check_true(PlacesUtils.annotations.itemHasAnnotation(testFolder.itemId,
|
|
|
|
DESCRIPTION_ANNO));
|
|
|
|
do_check_eq("folder test comment",
|
|
|
|
PlacesUtils.annotations.getItemAnnotation(testFolder.itemId, DESCRIPTION_ANNO));
|
|
|
|
// open test folder, and test the children
|
|
|
|
testFolder.containerOpen = true;
|
|
|
|
var cc = testFolder.childCount;
|
|
|
|
// XXX Bug 380468
|
|
|
|
// do_check_eq(cc, 2);
|
|
|
|
do_check_eq(cc, 1);
|
|
|
|
|
|
|
|
// test bookmark 1
|
|
|
|
var testBookmark1 = testFolder.getChild(0);
|
|
|
|
// url
|
|
|
|
do_check_eq("http://test/post", testBookmark1.uri);
|
|
|
|
// title
|
|
|
|
do_check_eq("test post keyword", testBookmark1.title);
|
|
|
|
// keyword
|
|
|
|
do_check_eq("test", PlacesUtils.bookmarks.getKeywordForBookmark(testBookmark1.itemId));
|
|
|
|
// sidebar
|
|
|
|
do_check_true(PlacesUtils.annotations.itemHasAnnotation(testBookmark1.itemId,
|
|
|
|
LOAD_IN_SIDEBAR_ANNO));
|
|
|
|
/*
|
|
|
|
// add date
|
|
|
|
do_check_eq(testBookmark1.dateAdded/1000000, 1177375336);
|
|
|
|
|
|
|
|
// last modified
|
|
|
|
do_check_eq(testBookmark1.lastModified/1000000, 1177375423);
|
|
|
|
*/
|
|
|
|
|
|
|
|
// post data
|
|
|
|
do_check_true(PlacesUtils.annotations.itemHasAnnotation(testBookmark1.itemId, POST_DATA_ANNO));
|
|
|
|
do_check_eq("hidden1%3Dbar&text1%3D%25s",
|
|
|
|
PlacesUtils.annotations.getItemAnnotation(testBookmark1.itemId, POST_DATA_ANNO));
|
|
|
|
|
2008-04-08 11:41:04 -07:00
|
|
|
// last charset
|
|
|
|
var testURI = PlacesUtils._uri(testBookmark1.uri);
|
|
|
|
do_check_eq("ISO-8859-1", PlacesUtils.history.getCharsetForURI(testURI));
|
|
|
|
|
2008-03-13 12:25:49 -07:00
|
|
|
// description
|
|
|
|
do_check_true(PlacesUtils.annotations.itemHasAnnotation(testBookmark1.itemId,
|
|
|
|
DESCRIPTION_ANNO));
|
|
|
|
do_check_eq("item description",
|
|
|
|
PlacesUtils.annotations.getItemAnnotation(testBookmark1.itemId,
|
|
|
|
DESCRIPTION_ANNO));
|
|
|
|
|
|
|
|
/*
|
|
|
|
// XXX Bug 380468
|
|
|
|
// test bookmark 2
|
|
|
|
var testBookmark2 = testFolder.getChild(1);
|
|
|
|
// url
|
|
|
|
do_check_eq("http://test/micsum", testBookmark2.uri);
|
|
|
|
// title
|
|
|
|
do_check_eq("test microsummary", testBookmark2.title);
|
|
|
|
// check that it's a microsummary
|
|
|
|
var micsum = mssvc.getMicrosummary(testBookmark2.itemId);
|
|
|
|
if (!micsum)
|
|
|
|
do_throw("Could not import microsummary");
|
|
|
|
// check generator uri
|
|
|
|
var generator = micsum.generator;
|
|
|
|
do_check_eq("urn:source:http://dietrich.ganx4.com/mozilla/test-microsummary.xml", generator.uri.spec);
|
|
|
|
// expiration and generated title can change, so don't test them
|
|
|
|
*/
|
|
|
|
|
|
|
|
// clean up
|
|
|
|
testFolder.containerOpen = false;
|
|
|
|
rootNode.containerOpen = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
function testToolbarFolder() {
|
|
|
|
var query = PlacesUtils.history.getNewQuery();
|
|
|
|
query.setFolders([PlacesUtils.bookmarks.toolbarFolder], 1);
|
|
|
|
var result = PlacesUtils.history.executeQuery(query, PlacesUtils.history.getNewQueryOptions());
|
|
|
|
|
|
|
|
var toolbar = result.root;
|
|
|
|
toolbar.containerOpen = true;
|
|
|
|
|
|
|
|
// child count (add 2 for pre-existing items)
|
|
|
|
do_check_eq(toolbar.childCount, bookmarkData.length + 2);
|
|
|
|
|
|
|
|
// livemark
|
|
|
|
var livemark = toolbar.getChild(1);
|
|
|
|
// title
|
|
|
|
do_check_eq("Latest Headlines", livemark.title);
|
|
|
|
// livemark check
|
|
|
|
do_check_true(PlacesUtils.livemarks.isLivemark(livemark.itemId));
|
|
|
|
// site url
|
|
|
|
do_check_eq("http://en-us.fxfeeds.mozilla.com/en-US/firefox/livebookmarks/",
|
|
|
|
PlacesUtils.livemarks.getSiteURI(livemark.itemId).spec);
|
|
|
|
// feed url
|
|
|
|
do_check_eq("http://en-us.fxfeeds.mozilla.com/en-US/firefox/headlines.xml",
|
|
|
|
PlacesUtils.livemarks.getFeedURI(livemark.itemId).spec);
|
|
|
|
|
|
|
|
// test added bookmark data
|
|
|
|
var child = toolbar.getChild(2);
|
|
|
|
do_check_eq(child.uri, bookmarkData[0].uri.spec);
|
|
|
|
do_check_eq(child.title, bookmarkData[0].title);
|
|
|
|
child = toolbar.getChild(3);
|
|
|
|
do_check_eq(child.uri, bookmarkData[1].uri.spec);
|
|
|
|
do_check_eq(child.title, bookmarkData[1].title);
|
|
|
|
|
|
|
|
toolbar.containerOpen = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
function testUnfiledBookmarks() {
|
|
|
|
var query = PlacesUtils.history.getNewQuery();
|
|
|
|
query.setFolders([PlacesUtils.bookmarks.unfiledBookmarksFolder], 1);
|
|
|
|
var result = PlacesUtils.history.executeQuery(query, PlacesUtils.history.getNewQueryOptions());
|
|
|
|
var rootNode = result.root;
|
|
|
|
rootNode.containerOpen = true;
|
2008-04-01 11:26:09 -07:00
|
|
|
// child count (add 1 for pre-existing item)
|
|
|
|
do_check_eq(rootNode.childCount, bookmarkData.length + 1);
|
|
|
|
for (var i = 1; i < rootNode.childCount; i++) {
|
2008-03-13 12:25:49 -07:00
|
|
|
var child = rootNode.getChild(i);
|
2008-04-01 11:26:09 -07:00
|
|
|
dump(bookmarkData[i - 1].uri.spec + " == " + child.uri + "?\n");
|
|
|
|
do_check_true(bookmarkData[i - 1].uri.equals(uri(child.uri)));
|
|
|
|
do_check_eq(child.title, bookmarkData[i - 1].title);
|
2008-03-13 12:25:49 -07:00
|
|
|
/* WTF
|
|
|
|
if (child.tags)
|
|
|
|
do_check_eq(child.tags, bookmarkData[i].title);
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
rootNode.containerOpen = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
function testTags() {
|
|
|
|
for each(let {uri: u, tags: t} in tagData) {
|
|
|
|
var i = 0;
|
|
|
|
dump("test tags for " + u.spec + ": " + t + "\n");
|
2009-11-02 13:04:15 -08:00
|
|
|
var tt = PlacesUtils.tagging.getTagsForURI(u);
|
2008-03-13 12:25:49 -07:00
|
|
|
dump("true tags for " + u.spec + ": " + tt + "\n");
|
|
|
|
do_check_true(t.every(function(el) {
|
|
|
|
i++;
|
|
|
|
return tt.indexOf(el) > -1;
|
|
|
|
}));
|
|
|
|
do_check_eq(i, t.length);
|
|
|
|
}
|
2008-02-27 10:14:13 -08:00
|
|
|
}
|