зеркало из https://github.com/mozilla/gecko-dev.git
120 строки
4.2 KiB
JavaScript
120 строки
4.2 KiB
JavaScript
// tests nsIPermissionManager
|
|
|
|
var hosts = [
|
|
// format: [host, type, permission]
|
|
["http://mozilla.org", "cookie", 1],
|
|
["http://mozilla.org", "image", 2],
|
|
["http://mozilla.org", "popup", 3],
|
|
["http://mozilla.com", "cookie", 1],
|
|
["http://www.mozilla.com", "cookie", 2],
|
|
["http://dev.mozilla.com", "cookie", 3]
|
|
];
|
|
|
|
var results = [
|
|
// format: [host, type, testPermission result, testExactPermission result]
|
|
// test defaults
|
|
["http://localhost", "cookie", 0, 0],
|
|
["http://spreadfirefox.com", "cookie", 0, 0],
|
|
// test different types
|
|
["http://mozilla.org", "cookie", 1, 1],
|
|
["http://mozilla.org", "image", 2, 2],
|
|
["http://mozilla.org", "popup", 3, 3],
|
|
// test subdomains
|
|
["http://www.mozilla.org", "cookie", 1, 0],
|
|
["http://www.dev.mozilla.org", "cookie", 1, 0],
|
|
// test different permissions on subdomains
|
|
["http://mozilla.com", "cookie", 1, 1],
|
|
["http://www.mozilla.com", "cookie", 2, 2],
|
|
["http://dev.mozilla.com", "cookie", 3, 3],
|
|
["http://www.dev.mozilla.com", "cookie", 3, 0]
|
|
];
|
|
|
|
function run_test() {
|
|
var pm = Components.classes["@mozilla.org/permissionmanager;1"]
|
|
.getService(Components.interfaces.nsIPermissionManager);
|
|
|
|
var ioService = Components.classes["@mozilla.org/network/io-service;1"]
|
|
.getService(Components.interfaces.nsIIOService);
|
|
|
|
var secMan = Components.classes["@mozilla.org/scriptsecuritymanager;1"]
|
|
.getService(Components.interfaces.nsIScriptSecurityManager);
|
|
|
|
// nsIPermissionManager implementation is an extension; don't fail if it's not there
|
|
if (!pm)
|
|
return;
|
|
|
|
// put a few hosts in
|
|
for (var i = 0; i < hosts.length; ++i) {
|
|
let uri = ioService.newURI(hosts[i][0], null, null);
|
|
let principal = secMan.createCodebasePrincipal(uri, {});
|
|
|
|
pm.addFromPrincipal(principal, hosts[i][1], hosts[i][2]);
|
|
}
|
|
|
|
// test the result
|
|
for (var i = 0; i < results.length; ++i) {
|
|
let uri = ioService.newURI(results[i][0], null, null);
|
|
let principal = secMan.createCodebasePrincipal(uri, {});
|
|
|
|
do_check_eq(pm.testPermissionFromPrincipal(principal, results[i][1]), results[i][2]);
|
|
do_check_eq(pm.testExactPermissionFromPrincipal(principal, results[i][1]), results[i][3]);
|
|
}
|
|
|
|
// test the enumerator ...
|
|
var j = 0;
|
|
var perms = new Array();
|
|
var enumerator = pm.enumerator;
|
|
while (enumerator.hasMoreElements()) {
|
|
perms[j] = enumerator.getNext().QueryInterface(Components.interfaces.nsIPermission);
|
|
++j;
|
|
}
|
|
do_check_eq(perms.length, hosts.length);
|
|
|
|
// ... remove all the hosts ...
|
|
for (var j = 0; j < perms.length; ++j) {
|
|
pm.removePermission(perms[j]);
|
|
}
|
|
|
|
// ... ensure each and every element is equal ...
|
|
for (var i = 0; i < hosts.length; ++i) {
|
|
for (var j = 0; j < perms.length; ++j) {
|
|
if (perms[j].matchesURI(ioService.newURI(hosts[i][0], null, null), true) &&
|
|
hosts[i][1] == perms[j].type &&
|
|
hosts[i][2] == perms[j].capability) {
|
|
perms.splice(j, 1);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
do_check_eq(perms.length, 0);
|
|
|
|
// ... and check the permmgr's empty
|
|
do_check_eq(pm.enumerator.hasMoreElements(), false);
|
|
|
|
// test UTF8 normalization behavior: expect ASCII/ACE host encodings
|
|
var utf8 = "b\u00FCcher.dolske.org"; // "bücher.dolske.org"
|
|
var aceref = "xn--bcher-kva.dolske.org";
|
|
var uri = ioService.newURI("http://" + utf8, null, null);
|
|
pm.add(uri, "utf8", 1);
|
|
var enumerator = pm.enumerator;
|
|
do_check_eq(enumerator.hasMoreElements(), true);
|
|
var ace = enumerator.getNext().QueryInterface(Components.interfaces.nsIPermission);
|
|
do_check_eq(ace.principal.URI.asciiHost, aceref);
|
|
do_check_eq(enumerator.hasMoreElements(), false);
|
|
|
|
// test removeAll()
|
|
pm.removeAll();
|
|
do_check_eq(pm.enumerator.hasMoreElements(), false);
|
|
|
|
uri = ioService.newURI("https://www.example.com", null, null);
|
|
pm.add(uri, "offline-app", pm.ALLOW_ACTION);
|
|
principal = secMan.createCodebasePrincipalFromOrigin("https://www.example.com");
|
|
// Remove existing entry.
|
|
perm = pm.getPermissionObject(principal, "offline-app", true);
|
|
pm.removePermission(perm);
|
|
// Try to remove already deleted entry.
|
|
perm = pm.getPermissionObject(principal, "offline-app", true);
|
|
pm.removePermission(perm);
|
|
do_check_eq(pm.enumerator.hasMoreElements(), false);
|
|
}
|