blob: b0e3ffc42bf3383ec1f0f4243c3b38727dc19e46 (
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
|
// ----------------------------------------------------------------------------
// Test whether an install fails if the url is a local file when requested from
// web content
add_task(function* test() {
var cr = Components.classes["@mozilla.org/chrome/chrome-registry;1"]
.getService(Components.interfaces.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?" + triggers;
yield BrowserTestUtils.withNewTab({ gBrowser, url: "about:blank" }, function* (browser) {
yield ContentTask.spawn(browser, URI, function* (URI) {
content.location.href = URI;
let loaded = ContentTaskUtils.waitForEvent(this, "load", true);
let installTriggered = ContentTaskUtils.waitForEvent(this, "InstallTriggered", true, null, true);
yield Promise.all([ loaded, installTriggered ]);
let doc = content.document;
is(doc.getElementById("return").textContent, "exception", "installTrigger should have failed");
});
});
});
// ----------------------------------------------------------------------------
|