mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-30 21:55:31 +00:00
50 lines
2.2 KiB
JavaScript
50 lines
2.2 KiB
JavaScript
Components.utils.import("resource://gre/modules/Services.jsm");
|
|
Components.utils.import("resource://gre/modules/XPCOMUtils.jsm");
|
|
|
|
function createURI(s) {
|
|
let service = Components.classes["@mozilla.org/network/io-service;1"]
|
|
.getService(Components.interfaces.nsIIOService);
|
|
return service.newURI(s);
|
|
}
|
|
|
|
function run_test() {
|
|
// Set up a profile.
|
|
do_get_profile();
|
|
|
|
var secMan = Cc["@mozilla.org/scriptsecuritymanager;1"].getService(Ci.nsIScriptSecurityManager);
|
|
const kURI1 = "http://example.com";
|
|
var app1 = secMan.createCodebasePrincipal(createURI(kURI1), {appId: 1});
|
|
var app10 = secMan.createCodebasePrincipal(createURI(kURI1),{appId: 10});
|
|
var app1browser = secMan.createCodebasePrincipal(createURI(kURI1), {appId: 1, inIsolatedMozBrowser: true});
|
|
|
|
var am = Cc["@mozilla.org/network/http-auth-manager;1"].
|
|
getService(Ci.nsIHttpAuthManager);
|
|
am.setAuthIdentity("http", "a.example.com", -1, "basic", "realm", "", "example.com", "user", "pass", false, app1);
|
|
am.setAuthIdentity("http", "a.example.com", -1, "basic", "realm", "", "example.com", "user3", "pass3", false, app1browser);
|
|
am.setAuthIdentity("http", "a.example.com", -1, "basic", "realm", "", "example.com", "user2", "pass2", false, app10);
|
|
|
|
let attrs_inBrowser = JSON.stringify({ appId:1, inIsolatedMozBrowser:true });
|
|
Services.obs.notifyObservers(null, "clear-origin-attributes-data", attrs_inBrowser);
|
|
|
|
var domain = {value: ""}, user = {value: ""}, pass = {value: ""};
|
|
try {
|
|
am.getAuthIdentity("http", "a.example.com", -1, "basic", "realm", "", domain, user, pass, false, app1browser);
|
|
do_check_false(true); // no identity should be present
|
|
} catch (x) {
|
|
do_check_eq(domain.value, "");
|
|
do_check_eq(user.value, "");
|
|
do_check_eq(pass.value, "");
|
|
}
|
|
|
|
am.getAuthIdentity("http", "a.example.com", -1, "basic", "realm", "", domain, user, pass, false, app1);
|
|
do_check_eq(domain.value, "example.com");
|
|
do_check_eq(user.value, "user");
|
|
do_check_eq(pass.value, "pass");
|
|
|
|
|
|
am.getAuthIdentity("http", "a.example.com", -1, "basic", "realm", "", domain, user, pass, false, app10);
|
|
do_check_eq(domain.value, "example.com");
|
|
do_check_eq(user.value, "user2");
|
|
do_check_eq(pass.value, "pass2");
|
|
}
|