blob: b092ac9a4c10c7954377cea873845e20ea9f4760 (
plain)
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
|
// ----------------------------------------------------------------------------
// Test whether an install fails if the url is a local file when requested from
// web content
add_task(async function test() {
var cr = Cc["@mozilla.org/chrome/chrome-registry;1"].getService(
Ci.nsIChromeRegistry
);
var chromeroot = getChromeRoot(gTestPath);
var xpipath = chromeroot + "amosigned.xpi";
try {
xpipath = cr.convertChromeURL(makeURI(xpipath)).spec;
} catch (ex) {
// scenario where we are running from a .jar and already extracted
}
var triggers = encodeURIComponent(
JSON.stringify({
"Unsigned XPI": xpipath,
})
);
// In non-e10s the exception in the content page would trigger a test failure
if (!gMultiProcessBrowser) {
expectUncaughtException();
}
let URI = TESTROOT + "installtrigger.html?manualStartInstall" + triggers;
await BrowserTestUtils.withNewTab({ gBrowser, url: URI }, async function(
browser
) {
await SpecialPowers.spawn(browser, [], async function() {
let installTriggered = ContentTaskUtils.waitForEvent(
docShell.chromeEventHandler,
"InstallTriggered",
true,
null,
true
);
content.wrappedJSObject.startInstall();
await installTriggered;
let doc = content.document;
is(
doc.getElementById("return").textContent,
"exception",
"installTrigger should have failed"
);
});
});
});
// ----------------------------------------------------------------------------
|