Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
/* Any copyright is dedicated to the Public Domain.
var attrs;
function matches_always(perm, principals) {
principals.forEach(principal => {
Assert.ok(
perm.matches(principal, true),
"perm: " + perm.principal.origin + ", princ: " + principal.origin
);
Assert.ok(
perm.matches(principal, false),
"perm: " + perm.principal.origin + ", princ: " + principal.origin
);
});
}
function matches_weak(perm, principals) {
principals.forEach(principal => {
Assert.ok(
!perm.matches(principal, true),
"perm: " + perm.principal.origin + ", princ: " + principal.origin
);
Assert.ok(
perm.matches(principal, false),
"perm: " + perm.principal.origin + ", princ: " + principal.origin
);
});
}
function matches_never(perm, principals) {
principals.forEach(principal => {
Assert.ok(
!perm.matches(principal, true),
"perm: " + perm.principal.origin + ", princ: " + principal.origin
);
Assert.ok(
!perm.matches(principal, false),
"perm: " + perm.principal.origin + ", princ: " + principal.origin
);
});
}
function run_test() {
// initialize the permission manager service
let pm = Services.perms;
let secMan = Services.scriptSecurityManager;
// Add some permissions
let uri0_n = secMan.createContentPrincipal(uri0, {});
let uri1_n = secMan.createContentPrincipal(uri1, {});
let uri2_n = secMan.createContentPrincipal(uri2, {});
let uri3_n = secMan.createContentPrincipal(uri3, {});
let uri4_n = secMan.createContentPrincipal(uri4, {});
let uri5_n = secMan.createContentPrincipal(uri5, {});
attrs = { userContextId: 1 };
let uri0_1 = secMan.createContentPrincipal(uri0, attrs);
let uri1_1 = secMan.createContentPrincipal(uri1, attrs);
let uri2_1 = secMan.createContentPrincipal(uri2, attrs);
let uri3_1 = secMan.createContentPrincipal(uri3, attrs);
let uri4_1 = secMan.createContentPrincipal(uri4, attrs);
let uri5_1 = secMan.createContentPrincipal(uri5, attrs);
attrs = { firstPartyDomain: "cnn.com" };
let uri0_cnn = secMan.createContentPrincipal(uri0, attrs);
let uri1_cnn = secMan.createContentPrincipal(uri1, attrs);
let uri2_cnn = secMan.createContentPrincipal(uri2, attrs);
let uri3_cnn = secMan.createContentPrincipal(uri3, attrs);
let uri4_cnn = secMan.createContentPrincipal(uri4, attrs);
let uri5_cnn = secMan.createContentPrincipal(uri5, attrs);
pm.addFromPrincipal(uri0_n, "test/matches", pm.ALLOW_ACTION);
let perm_n = pm.getPermissionObject(uri0_n, "test/matches", true);
pm.addFromPrincipal(uri0_1, "test/matches", pm.ALLOW_ACTION);
let perm_1 = pm.getPermissionObject(uri0_n, "test/matches", true);
pm.addFromPrincipal(uri0_cnn, "test/matches", pm.ALLOW_ACTION);
let perm_cnn = pm.getPermissionObject(uri0_n, "test/matches", true);
matches_always(perm_n, [uri0_n, uri0_1]);
matches_weak(perm_n, [uri1_n, uri1_1]);
matches_never(perm_n, [
uri2_n,
uri3_n,
uri4_n,
uri5_n,
uri2_1,
uri3_1,
uri4_1,
uri5_1,
uri0_cnn,
uri1_cnn,
uri2_cnn,
uri3_cnn,
uri4_cnn,
uri5_cnn,
]);
matches_always(perm_1, [uri0_n, uri0_1]);
matches_weak(perm_1, [uri1_n, uri1_1]);
matches_never(perm_1, [
uri2_n,
uri3_n,
uri4_n,
uri5_n,
uri2_1,
uri3_1,
uri4_1,
uri5_1,
uri0_cnn,
uri1_cnn,
uri2_cnn,
uri3_cnn,
uri4_cnn,
uri5_cnn,
]);
matches_always(perm_cnn, [uri0_n, uri0_1]);
matches_weak(perm_cnn, [uri1_n, uri1_1]);
matches_never(perm_cnn, [
uri2_n,
uri3_n,
uri4_n,
uri5_n,
uri2_1,
uri3_1,
uri4_1,
uri5_1,
uri0_cnn,
uri1_cnn,
uri2_cnn,
uri3_cnn,
uri4_cnn,
uri5_cnn,
]);
// Clean up!
pm.removeAll();
}