diff options
author | Matt A. Tobin <email@mattatobin.com> | 2018-02-10 02:51:36 -0500 |
---|---|---|
committer | Matt A. Tobin <email@mattatobin.com> | 2018-02-10 02:51:36 -0500 |
commit | 37d5300335d81cecbecc99812747a657588c63eb (patch) | |
tree | 765efa3b6a56bb715d9813a8697473e120436278 /toolkit/mozapps/webextensions/test/xpcshell/test_safemode.js | |
parent | b2bdac20c02b12f2057b9ef70b0a946113a00e00 (diff) | |
parent | 4fb11cd5966461bccc3ed1599b808237be6b0de9 (diff) | |
download | UXP-37d5300335d81cecbecc99812747a657588c63eb.tar UXP-37d5300335d81cecbecc99812747a657588c63eb.tar.gz UXP-37d5300335d81cecbecc99812747a657588c63eb.tar.lz UXP-37d5300335d81cecbecc99812747a657588c63eb.tar.xz UXP-37d5300335d81cecbecc99812747a657588c63eb.zip |
Merge branch 'ext-work'
Diffstat (limited to 'toolkit/mozapps/webextensions/test/xpcshell/test_safemode.js')
-rw-r--r-- | toolkit/mozapps/webextensions/test/xpcshell/test_safemode.js | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/toolkit/mozapps/webextensions/test/xpcshell/test_safemode.js b/toolkit/mozapps/webextensions/test/xpcshell/test_safemode.js new file mode 100644 index 000000000..05647f807 --- /dev/null +++ b/toolkit/mozapps/webextensions/test/xpcshell/test_safemode.js @@ -0,0 +1,115 @@ +/* Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/publicdomain/zero/1.0/ + */ + +Components.utils.import("resource://gre/modules/NetUtil.jsm"); + +// Tests that extensions behave correctly in safe mode + +var addon1 = { + id: "addon1@tests.mozilla.org", + version: "1.0", + name: "Test 1", + optionsURL: "chrome://foo/content/options.xul", + aboutURL: "chrome://foo/content/about.xul", + iconURL: "chrome://foo/content/icon.png", + targetApplications: [{ + id: "xpcshell@tests.mozilla.org", + minVersion: "1", + maxVersion: "1" + }] +}; + +const profileDir = gProfD.clone(); +profileDir.append("extensions"); + +var gIconURL = null; + +// Sets up the profile by installing an add-on. +function run_test() { + do_test_pending(); + createAppInfo("xpcshell@tests.mozilla.org", "XPCShell", "1", "1.9.2"); + gAppInfo.inSafeMode = true; + + startupManager(); + + AddonManager.getAddonByID("addon1@tests.mozilla.org", callback_soon(function(a1) { + do_check_eq(a1, null); + do_check_not_in_crash_annotation(addon1.id, addon1.version); + + writeInstallRDFForExtension(addon1, profileDir, addon1.id, "icon.png"); + gIconURL = do_get_addon_root_uri(profileDir.clone(), addon1.id) + "icon.png"; + + restartManager(); + + AddonManager.getAddonByID("addon1@tests.mozilla.org", function(newa1) { + do_check_neq(newa1, null); + do_check_false(newa1.isActive); + do_check_false(newa1.userDisabled); + do_check_eq(newa1.aboutURL, null); + do_check_eq(newa1.optionsURL, null); + do_check_eq(newa1.iconURL, gIconURL); + do_check_true(isExtensionInAddonsList(profileDir, newa1.id)); + do_check_true(hasFlag(newa1.permissions, AddonManager.PERM_CAN_DISABLE)); + do_check_false(hasFlag(newa1.permissions, AddonManager.PERM_CAN_ENABLE)); + do_check_eq(newa1.operationsRequiringRestart, AddonManager.OP_NEEDS_RESTART_NONE); + do_check_not_in_crash_annotation(addon1.id, addon1.version); + + run_test_1(); + }); + })); +} + +// Disabling an add-on should work +function run_test_1() { + prepare_test({ + "addon1@tests.mozilla.org": [ + ["onDisabling", false], + "onDisabled" + ] + }); + + AddonManager.getAddonByID("addon1@tests.mozilla.org", function(a1) { + do_check_false(hasFlag(a1.operationsRequiringRestart, + AddonManager.OP_NEEDS_RESTART_DISABLE)); + a1.userDisabled = true; + do_check_false(a1.isActive); + do_check_eq(a1.aboutURL, null); + do_check_eq(a1.optionsURL, null); + do_check_eq(a1.iconURL, gIconURL); + do_check_false(hasFlag(a1.permissions, AddonManager.PERM_CAN_DISABLE)); + do_check_true(hasFlag(a1.permissions, AddonManager.PERM_CAN_ENABLE)); + do_check_eq(a1.operationsRequiringRestart, AddonManager.OP_NEEDS_RESTART_NONE); + do_check_not_in_crash_annotation(addon1.id, addon1.version); + + ensure_test_completed(); + + run_test_2(); + }); +} + +// Enabling an add-on should happen without restart but not become active. +function run_test_2() { + prepare_test({ + "addon1@tests.mozilla.org": [ + ["onEnabling", false], + "onEnabled" + ] + }); + + AddonManager.getAddonByID("addon1@tests.mozilla.org", function(a1) { + a1.userDisabled = false; + do_check_false(a1.isActive); + do_check_eq(a1.aboutURL, null); + do_check_eq(a1.optionsURL, null); + do_check_eq(a1.iconURL, gIconURL); + do_check_true(hasFlag(a1.permissions, AddonManager.PERM_CAN_DISABLE)); + do_check_false(hasFlag(a1.permissions, AddonManager.PERM_CAN_ENABLE)); + do_check_eq(a1.operationsRequiringRestart, AddonManager.OP_NEEDS_RESTART_NONE); + do_check_not_in_crash_annotation(addon1.id, addon1.version); + + ensure_test_completed(); + + do_execute_soon(do_test_finished); + }); +} |