Source code
Revision control
Copy as Markdown
Other Tools
Test Info: Warnings
- This test gets skipped with pattern: os == 'android'
- Manifest: browser/components/enterprisepolicies/tests/xpcshell/xpcshell.toml
/* Any copyright is dedicated to the Public Domain.
"use strict";
async function checkMessages(expectedResult) {
let onBeforeAddons = false;
let onProfileAfterChange = false;
let onBeforeUIStartup = false;
let onAllWindowsRestored = false;
let errorListener = {
observe(subject) {
let message = subject.wrappedJSObject.arguments[0];
if (message.includes("_cleanup from onBeforeAddons")) {
onBeforeAddons = true;
} else if (message.includes("_cleanup from onProfileAfterChange")) {
onProfileAfterChange = true;
} else if (message.includes("_cleanup from onBeforeUIStartup")) {
onBeforeUIStartup = true;
} else if (message.includes("_cleanup from onAllWindowsRestored")) {
onAllWindowsRestored = true;
}
},
};
Services.console.registerListener(errorListener);
const ConsoleAPIStorage = Cc["@mozilla.org/consoleAPI-storage;1"].getService(
Ci.nsIConsoleAPIStorage
);
ConsoleAPIStorage.addLogEventListener(
errorListener.observe,
Cc["@mozilla.org/systemprincipal;1"].createInstance(Ci.nsIPrincipal)
);
await setupPolicyEngineWithJson({
policies: {},
});
equal(
onBeforeAddons,
expectedResult,
"onBeforeAddons should be " + expectedResult
);
equal(
onProfileAfterChange,
expectedResult,
"onProfileAfterChange should be" + expectedResult
);
equal(
onBeforeUIStartup,
expectedResult,
"onBeforeUIStartup should be" + expectedResult
);
equal(
onAllWindowsRestored,
expectedResult,
"onAllWindowsRestored should be" + expectedResult
);
}
/* If there is no existing policy, cleanup should not run. */
add_task(async function test_cleanup_no_policy() {
await checkMessages(false);
});
add_task(async function setup_policy() {
await setupPolicyEngineWithJson({
policies: {
BlockAboutConfig: true,
},
});
});
/* Since there was a policy, cleanup should run. */
add_task(async function test_cleanup_with_policy() {
await checkMessages(true);
});
/* Since cleanup was already done, cleanup should not run again. */
add_task(async function test_cleanup_after_policy() {
await checkMessages(false);
});