1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
// Test whether a request for auth for an XPI switches to the appropriate tab
var gNewTab;
function test() {
// This test depends on InstallTrigger.install availability.
setInstallTriggerPrefs();
// Turn off the authentication dialog blocking for this test.
Services.prefs.setBoolPref(
"network.auth.non-web-content-triggered-resources-http-auth-allow",
true
);
Harness.authenticationCallback = get_auth_info;
Harness.downloadFailedCallback = download_failed;
Harness.installEndedCallback = install_ended;
Harness.installsCompletedCallback = finish_test;
Harness.setup();
PermissionTestUtils.add(
"http://example.com/",
"install",
Services.perms.ALLOW_ACTION
);
var triggers = encodeURIComponent(
JSON.stringify({
"Unsigned XPI":
TESTROOT + "authRedirect.sjs?" + TESTROOT + "amosigned.xpi",
})
);
gNewTab = BrowserTestUtils.addTab(gBrowser);
BrowserTestUtils.startLoadingURIString(
gBrowser.getBrowserForTab(gNewTab),
TESTROOT + "installtrigger.html?" + triggers
);
}
function get_auth_info() {
is(
gBrowser.selectedTab,
gNewTab,
"Should have focused the tab loading the XPI"
);
return ["testuser", "testpass"];
}
function download_failed(install) {
ok(false, "Install should not have failed");
}
function install_ended(install, addon) {
return addon.uninstall();
}
function finish_test(count) {
is(count, 1, "1 Add-on should have been successfully installed");
var authMgr = Cc["@mozilla.org/network/http-auth-manager;1"].getService(
Ci.nsIHttpAuthManager
);
authMgr.clearAll();
PermissionTestUtils.remove("http://example.com", "install");
Services.prefs.clearUserPref(
"network.auth.non-web-content-triggered-resources-http-auth-allow"
);
gBrowser.removeTab(gNewTab);
Harness.finish();
}
|