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_permissions.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_permissions.js')
-rw-r--r-- | toolkit/mozapps/webextensions/test/xpcshell/test_permissions.js | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/toolkit/mozapps/webextensions/test/xpcshell/test_permissions.js b/toolkit/mozapps/webextensions/test/xpcshell/test_permissions.js new file mode 100644 index 000000000..48fef406f --- /dev/null +++ b/toolkit/mozapps/webextensions/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"))); +} |