fune/browser/components/enterprisepolicies/tests/browser/browser_policy_bookmarks.js
Doug Thayer 0fd7f560d6 Bug 1426245 - Test changes r=mak
MozReview-Commit-ID: 4fhhzspxLJZ

Depends on D4606

Differential Revision: https://phabricator.services.mozilla.com/D5162

--HG--
extra : moz-landing-system : lando
2018-10-09 14:47:31 +00:00

275 lines
8.4 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
ChromeUtils.import("resource://gre/modules/XPCOMUtils.jsm");
ChromeUtils.import("resource://gre/modules/Services.jsm");
ChromeUtils.import("resource://gre/modules/PlacesUtils.jsm");
const FAVICON_DATA = "";
const { BookmarksPolicies } = ChromeUtils.import("resource:///modules/policies/BookmarksPolicies.jsm", {});
let CURRENT_POLICY;
const BASE_POLICY = {
"policies": {
"DisplayBookmarksToolbar": true,
"Bookmarks": [
{
"Title": "Bookmark 1",
"URL": "https://bookmark1.example.com/",
"Favicon": FAVICON_DATA,
},
{
"Title": "Bookmark 2",
"URL": "https://bookmark2.example.com/",
"Folder": "Folder 1",
},
{
"Title": "Bookmark 3",
"URL": "https://bookmark3.example.com/",
"Placement": "menu",
},
{
"Title": "Bookmark 4",
"URL": "https://bookmark4.example.com/",
"Folder": "Folder 1",
},
{
"Title": "Bookmark 5",
"URL": "https://bookmark5.example.com/",
"Placement": "menu",
"Folder": "Folder 2",
},
],
},
};
/*
* =================================
* = HELPER FUNCTIONS FOR THE TEST =
* =================================
*/
function deepClone(obj) {
return JSON.parse(JSON.stringify(obj));
}
function findBookmarkInPolicy(bookmark) {
// Find the entry in the given policy that corresponds
// to this bookmark object from Places.
for (let entry of CURRENT_POLICY.policies.Bookmarks) {
if (entry.Title == bookmark.title) {
return entry;
}
}
return null;
}
async function promiseAllChangesMade({itemsToAdd, itemsToRemove}) {
return new Promise(resolve => {
let listener = events => {
is(events.length, 1, "Should only have 1 event.");
itemsToAdd--;
if (itemsToAdd == 0 && itemsToRemove == 0) {
PlacesUtils.bookmarks.removeObserver(bmObserver);
PlacesUtils.observers.removeListener(["bookmark-added"], listener);
resolve();
}
};
let bmObserver = {
onItemRemoved() {
itemsToRemove--;
if (itemsToAdd == 0 && itemsToRemove == 0) {
PlacesUtils.bookmarks.removeObserver(bmObserver);
PlacesUtils.observers.removeListener(["bookmark-added"], listener);
resolve();
}
},
onBeginUpdateBatch() {},
onEndUpdateBatch() {},
onItemChanged() {},
onItemVisited() {},
onItemMoved() {},
};
PlacesUtils.bookmarks.addObserver(bmObserver);
PlacesUtils.observers.addListener(["bookmark-added"], listener);
});
}
/*
* ==================
* = CHECK FUNCTION =
* ==================
*
* Performs all the checks comparing what was given in
* the policy JSON with what was retrieved from Places.
*/
async function check({expectedNumberOfFolders}) {
let bookmarks = [], folders = [];
await PlacesUtils.bookmarks.fetch({ guidPrefix: BookmarksPolicies.BOOKMARK_GUID_PREFIX }, (r) => {
bookmarks.push(r);
});
await PlacesUtils.bookmarks.fetch({ guidPrefix: BookmarksPolicies.FOLDER_GUID_PREFIX }, (r) => {
folders.push(r);
});
let foldersToGuids = new Map();
for (let folder of folders) {
is(folder.type, PlacesUtils.bookmarks.TYPE_FOLDER, "Correct type for folder");
foldersToGuids.set(folder.title, folder.guid);
}
// For simplification and accuracy purposes, the number of expected
// folders is manually specified in the test.
is(folders.length, expectedNumberOfFolders, "Correct number of folders expected");
is(foldersToGuids.size, expectedNumberOfFolders, "There aren't two different folders with the same name");
is(CURRENT_POLICY.policies.Bookmarks.length, bookmarks.length, "The correct number of bookmarks exist");
for (let bookmark of bookmarks) {
is(bookmark.type, PlacesUtils.bookmarks.TYPE_BOOKMARK, "Correct type for bookmark");
let entry = findBookmarkInPolicy(bookmark);
is(bookmark.title, entry.Title, "Title matches");
is(bookmark.url.href, entry.URL, "URL matches");
let expectedPlacementGuid;
if (entry.Folder) {
expectedPlacementGuid = foldersToGuids.get(entry.Folder);
} else {
expectedPlacementGuid = entry.Placement == "menu" ?
PlacesUtils.bookmarks.menuGuid :
PlacesUtils.bookmarks.toolbarGuid;
}
is(bookmark.parentGuid, expectedPlacementGuid, "Correctly placed");
}
}
/*
* ================
* = ACTUAL TESTS =
* ================
*
* Note: the order of these tests is important, as we want to test not
* only the end result of each configuration, but also the diff algorithm
* that will add or remove bookmarks depending on how the policy changed.
*/
add_task(async function test_initial_bookmarks() {
// Make a copy of the policy because we will be adding/removing entries from it
CURRENT_POLICY = deepClone(BASE_POLICY);
await Promise.all(
[
promiseAllChangesMade({
itemsToAdd: 7, // 5 bookmarks + 2 folders
itemsToRemove: 0,
}),
setupPolicyEngineWithJson(CURRENT_POLICY),
]);
await check({ expectedNumberOfFolders: 2 });
});
add_task(async function checkFavicon() {
let bookmark1url = CURRENT_POLICY.policies.Bookmarks[0].URL;
let result = await new Promise(resolve => {
PlacesUtils.favicons.getFaviconDataForPage(
Services.io.newURI(bookmark1url),
(uri, _, data) => resolve({uri, data})
);
});
is(result.uri.spec, "fake-favicon-uri:" + bookmark1url, "Favicon URI is correct");
// data is an array of octets, which will be a bit hard to compare against
// FAVICON_DATA, which is base64 encoded. Checking the expected length should
// be good indication that this is working properly.
is(result.data.length, 464, "Favicon data has the correct length");
let faviconsExpiredNotification = TestUtils.topicObserved("places-favicons-expired");
PlacesUtils.favicons.expireAllFavicons();
await faviconsExpiredNotification;
});
add_task(async function test_remove_Bookmark_2() {
// Continuing from the previous policy:
//
// Remove the 2nd bookmark. It is inside "Folder 1", but that
// folder won't be empty, so it must not be removed.
CURRENT_POLICY.policies.Bookmarks.splice(2, 1);
await Promise.all(
[
promiseAllChangesMade({
itemsToAdd: 0,
itemsToRemove: 1, // 1 bookmark
}),
setupPolicyEngineWithJson(CURRENT_POLICY),
]);
await check({ expectedNumberOfFolders: 2 });
});
add_task(async function test_remove_Bookmark_5() {
// Continuing from the previous policy:
//
// Remove the last bookmark in the policy,
// which means the "Folder 2" should also disappear
CURRENT_POLICY.policies.Bookmarks.splice(-1, 1);
await Promise.all(
[
promiseAllChangesMade({
itemsToAdd: 0,
itemsToRemove: 2, // 1 bookmark and 1 folder
}),
setupPolicyEngineWithJson(CURRENT_POLICY),
]);
await check({ expectedNumberOfFolders: 1 });
});
add_task(async function test_revert_to_original_policy() {
CURRENT_POLICY = deepClone(BASE_POLICY);
// Reverts to the original policy, which means that:
// - "Bookmark 2"
// - "Bookmark 5"
// - "Folder 2"
// should be recreated
await Promise.all(
[
promiseAllChangesMade({
itemsToAdd: 3, // 2 bookmarks and 1 folder
itemsToRemove: 0,
}),
setupPolicyEngineWithJson(CURRENT_POLICY),
]);
await check({ expectedNumberOfFolders: 2 });
});
// Leave this one at the end, so that it cleans up any
// bookmarks created during this test.
add_task(async function test_empty_all_bookmarks() {
CURRENT_POLICY = { policies: { Bookmarks: [] } };
await Promise.all(
[
promiseAllChangesMade({
itemsToAdd: 0,
itemsToRemove: 7, // 5 bookmarks and 2 folders
}),
setupPolicyEngineWithJson(CURRENT_POLICY),
]);
check({ expectedNumberOfFolders: 0 });
});