/* 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( "resource://gre/modules/Preferences.sys.mjs" ); const { SearchSettings } = ChromeUtils.importESModule( "resource://gre/modules/SearchSettings.sys.mjs" ); const { updateAppInfo, getAppInfo } = ChromeUtils.importESModule( "resource://testing-common/AppInfo.sys.mjs" ); const { FileTestUtils } = ChromeUtils.importESModule( "resource://testing-common/FileTestUtils.sys.mjs" ); const { PermissionTestUtils } = ChromeUtils.import( "resource://testing-common/PermissionTestUtils.jsm" ); ChromeUtils.defineESModuleGetters(lazy, { SearchTestUtils: "resource://testing-common/SearchTestUtils.sys.mjs", }); const { EnterprisePolicyTesting } = ChromeUtils.importESModule( "resource://testing-common/EnterprisePolicyTesting.sys.mjs" ); 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} policy * 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` ); equal( Preferences.get(prefName), prefValue, `Pref ${prefName} has the correct value` ); } function checkUnlockedPref(prefName, prefValue) { equal( Preferences.locked(prefName), false, `Pref ${prefName} is correctly unlocked` ); equal( Preferences.get(prefName), prefValue, `Pref ${prefName} has the correct value` ); } function checkUserPref(prefName, prefValue) { equal( Preferences.get(prefName), prefValue, `Pref ${prefName} has the correct value` ); } function checkClearPref(prefName, prefValue) { 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` ); } 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` ); }