diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | 5f8de423f190bbb79a62f804151bc24824fa32d8 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /toolkit/mozapps/extensions/test/xpcshell/test_permissions.js | |
parent | 49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff) | |
download | UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip |
Add m-esr52 at 52.6.0
Diffstat (limited to 'toolkit/mozapps/extensions/test/xpcshell/test_permissions.js')
-rw-r--r-- | toolkit/mozapps/extensions/test/xpcshell/test_permissions.js | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/toolkit/mozapps/extensions/test/xpcshell/test_permissions.js b/toolkit/mozapps/extensions/test/xpcshell/test_permissions.js new file mode 100644 index 000000000..48fef406f --- /dev/null +++ b/toolkit/mozapps/extensions/test/xpcshell/test_permissions.js @@ -0,0 +1,86 @@ +/* Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/publicdomain/zero/1.0/ + */ + +Components.utils.import("resource://gre/modules/NetUtil.jsm"); + +// Checks that permissions set in preferences are correctly imported but can +// be removed by the user. + +const XPI_MIMETYPE = "application/x-xpinstall"; + +function newPrincipal(uri) { + return Services.scriptSecurityManager.createCodebasePrincipal(NetUtil.newURI(uri), {}); +} + +function run_test() { + createAppInfo("xpcshell@tests.mozilla.org", "XPCShell", "2", "2"); + + Services.prefs.setCharPref("xpinstall.whitelist.add", "https://test1.com,https://test2.com"); + Services.prefs.setCharPref("xpinstall.whitelist.add.36", "https://test3.com,https://www.test4.com"); + Services.prefs.setCharPref("xpinstall.whitelist.add.test5", "https://test5.com"); + + Services.perms.add(NetUtil.newURI("https://www.test9.com"), "install", + AM_Ci.nsIPermissionManager.ALLOW_ACTION); + + startupManager(); + + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("http://test1.com"))); + do_check_true(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://test1.com"))); + do_check_true(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test2.com"))); + do_check_true(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://test3.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://test4.com"))); + do_check_true(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test4.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("http://www.test5.com"))); + do_check_true(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test5.com"))); + + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("http://www.test6.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test6.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://test7.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test8.com"))); + + // This should remain unaffected + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("http://www.test9.com"))); + do_check_true(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test9.com"))); + + Services.perms.removeAll(); + + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://test1.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test2.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://test3.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test4.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test5.com"))); + + // Upgrade the application and verify that the permissions are still not there + restartManager("2"); + + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://test1.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test2.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://test3.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test4.com"))); + do_check_false(AddonManager.isInstallAllowed(XPI_MIMETYPE, + newPrincipal("https://www.test5.com"))); +} |