Source code

Revision control

Copy as Markdown

Other Tools

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
"use strict";
const lazy = {};
const { Preferences } = ChromeUtils.importESModule(
);
const { SearchSettings } = ChromeUtils.importESModule(
);
const { updateAppInfo, getAppInfo } = ChromeUtils.importESModule(
);
const { FileTestUtils } = ChromeUtils.importESModule(
);
const { PermissionTestUtils } = ChromeUtils.importESModule(
);
ChromeUtils.defineESModuleGetters(lazy, {
});
const { EnterprisePolicyTesting } = ChromeUtils.importESModule(
);
updateAppInfo({
name: "XPCShell",
ID: "xpcshell@tests.mozilla.org",
version: "48",
platformVersion: "48",
});
// This initializes the policy engine for xpcshell tests
let policies = Cc["@mozilla.org/enterprisepolicies;1"].getService(
Ci.nsIObserver
);
policies.observe(null, "policies-startup", null);
SearchSettings.SETTINGS_INVALIDATION_DELAY = 100;
async function setupPolicyEngineWithJson(json, customSchema) {
if (typeof json != "object") {
let filePath = do_get_file(json ? json : "non-existing-file.json").path;
return EnterprisePolicyTesting.setupPolicyEngineWithJson(
filePath,
customSchema
);
}
return EnterprisePolicyTesting.setupPolicyEngineWithJson(json, customSchema);
}
/**
* Loads a new enterprise policy, and re-initialise the search service
* with the new policy. Also waits for the search service to write the settings
* file to disk.
*
* @param {object} json
* The enterprise policy to use.
* @param {object} customSchema
* A custom schema to use to validate the enterprise policy.
*/
async function setupPolicyEngineWithJsonWithSearch(json, customSchema) {
Services.search.wrappedJSObject.reset();
if (typeof json != "object") {
let filePath = do_get_file(json ? json : "non-existing-file.json").path;
await EnterprisePolicyTesting.setupPolicyEngineWithJson(
filePath,
customSchema
);
} else {
await EnterprisePolicyTesting.setupPolicyEngineWithJson(json, customSchema);
}
let settingsWritten = lazy.SearchTestUtils.promiseSearchNotification(
"write-settings-to-disk-complete"
);
await Services.search.init();
return settingsWritten;
}
function checkLockedPref(prefName, prefValue) {
equal(
Preferences.locked(prefName),
true,
`Pref ${prefName} is correctly locked`
);
strictEqual(
Preferences.get(prefName),
prefValue,
`Pref ${prefName} has the correct value`
);
}
function checkUnlockedPref(prefName, prefValue) {
equal(
Preferences.locked(prefName),
false,
`Pref ${prefName} is correctly unlocked`
);
strictEqual(
Preferences.get(prefName),
prefValue,
`Pref ${prefName} has the correct value`
);
}
function checkUserPref(prefName, prefValue) {
strictEqual(
Preferences.get(prefName),
prefValue,
`Pref ${prefName} has the correct value`
);
}
function checkClearPref(prefName) {
equal(
Services.prefs.prefHasUserValue(prefName),
false,
`Pref ${prefName} has no user value`
);
}
function checkDefaultPref(prefName, prefValue) {
let defaultPrefBranch = Services.prefs.getDefaultBranch("");
let prefType = defaultPrefBranch.getPrefType(prefName);
notEqual(
prefType,
Services.prefs.PREF_INVALID,
`Pref ${prefName} is set on the default branch`
);
strictEqual(
Preferences.get(prefName),
prefValue,
`Pref ${prefName} has the correct value`
);
}
function checkUnsetPref(prefName) {
let defaultPrefBranch = Services.prefs.getDefaultBranch("");
let prefType = defaultPrefBranch.getPrefType(prefName);
equal(
prefType,
Services.prefs.PREF_INVALID,
`Pref ${prefName} is not set on the default branch`
);
}