forked from mirrors/gecko-dev
MozReview-Commit-ID: 7pYfD6Ax5VX Differential Revision: https://phabricator.services.mozilla.com/D2971 --HG-- extra : moz-landing-system : lando
230 lines
7.7 KiB
JavaScript
230 lines
7.7 KiB
JavaScript
/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */
|
|
/* vim: set sts=2 sw=2 et tw=80: */
|
|
"use strict";
|
|
|
|
ChromeUtils.import("resource://gre/modules/ExtensionParent.jsm");
|
|
|
|
add_task(async function testExtensionDebuggingUtilsCleanup() {
|
|
const extension = ExtensionTestUtils.loadExtension({
|
|
background() {
|
|
browser.test.sendMessage("background.ready");
|
|
},
|
|
});
|
|
|
|
const expectedEmptyDebugUtils = {
|
|
hiddenXULWindow: null,
|
|
cacheSize: 0,
|
|
};
|
|
|
|
let {
|
|
hiddenXULWindow,
|
|
debugBrowserPromises,
|
|
} = ExtensionParent.DebugUtils;
|
|
|
|
deepEqual({hiddenXULWindow, cacheSize: debugBrowserPromises.size},
|
|
expectedEmptyDebugUtils,
|
|
"No ExtensionDebugUtils resources has been allocated yet");
|
|
|
|
await extension.startup();
|
|
|
|
await extension.awaitMessage("background.ready");
|
|
|
|
hiddenXULWindow = ExtensionParent.DebugUtils.hiddenXULWindow;
|
|
deepEqual({hiddenXULWindow, cacheSize: debugBrowserPromises.size},
|
|
expectedEmptyDebugUtils,
|
|
"No debugging resources has been yet allocated once the extension is running");
|
|
|
|
const fakeAddonActor = {
|
|
addonId: extension.id,
|
|
};
|
|
|
|
const anotherAddonActor = {
|
|
addonId: extension.id,
|
|
};
|
|
|
|
const waitFirstBrowser = ExtensionParent.DebugUtils.getExtensionProcessBrowser(fakeAddonActor);
|
|
const waitSecondBrowser = ExtensionParent.DebugUtils.getExtensionProcessBrowser(anotherAddonActor);
|
|
|
|
const addonDebugBrowser = await waitFirstBrowser;
|
|
equal(addonDebugBrowser.isRemoteBrowser, extension.extension.remote,
|
|
"The addon debugging browser has the expected remote type");
|
|
|
|
equal((await waitSecondBrowser), addonDebugBrowser,
|
|
"Two addon debugging actors related to the same addon get the same browser element ");
|
|
|
|
equal(debugBrowserPromises.size, 1, "The expected resources has been allocated");
|
|
|
|
const nonExistentAddonActor = {
|
|
addonId: "non-existent-addon@test",
|
|
};
|
|
|
|
const waitRejection = ExtensionParent.DebugUtils.getExtensionProcessBrowser(nonExistentAddonActor);
|
|
|
|
await Assert.rejects(waitRejection, /Extension not found/,
|
|
"Reject with the expected message for non existent addons");
|
|
|
|
equal(debugBrowserPromises.size, 1, "No additional debugging resources has been allocated");
|
|
|
|
await ExtensionParent.DebugUtils.releaseExtensionProcessBrowser(fakeAddonActor);
|
|
|
|
equal(debugBrowserPromises.size, 1,
|
|
"The addon debugging browser is cached until all the related actors have released it");
|
|
|
|
await ExtensionParent.DebugUtils.releaseExtensionProcessBrowser(anotherAddonActor);
|
|
|
|
hiddenXULWindow = ExtensionParent.DebugUtils.hiddenXULWindow;
|
|
|
|
deepEqual({hiddenXULWindow, cacheSize: debugBrowserPromises.size},
|
|
expectedEmptyDebugUtils,
|
|
"All the allocated debugging resources has been cleared");
|
|
|
|
await extension.unload();
|
|
});
|
|
|
|
add_task(async function testExtensionDebuggingUtilsAddonReloaded() {
|
|
let extension = ExtensionTestUtils.loadExtension({
|
|
manifest: {
|
|
applications: {
|
|
gecko: {
|
|
id: "test-reloaded@test.mozilla.com",
|
|
},
|
|
},
|
|
},
|
|
background() {
|
|
browser.test.sendMessage("background.ready");
|
|
},
|
|
});
|
|
|
|
await extension.startup();
|
|
await extension.awaitMessage("background.ready");
|
|
|
|
let fakeAddonActor = {
|
|
addonId: extension.id,
|
|
};
|
|
|
|
const addonDebugBrowser = await ExtensionParent.DebugUtils
|
|
.getExtensionProcessBrowser(fakeAddonActor);
|
|
equal(addonDebugBrowser.isRemoteBrowser, extension.extension.remote,
|
|
"The addon debugging browser has the expected remote type");
|
|
equal(ExtensionParent.DebugUtils.debugBrowserPromises.size, 1,
|
|
"Got the expected number of requested debug browsers");
|
|
|
|
const {chromeDocument} = ExtensionParent.DebugUtils.hiddenXULWindow;
|
|
|
|
ok(addonDebugBrowser.parentElement === chromeDocument.documentElement,
|
|
"The addon debugging browser is part of the hiddenXULWindow chromeDocument");
|
|
|
|
await extension.unload();
|
|
|
|
// Install an extension with the same id to recreate for the DebugUtils
|
|
// conditions similar to an addon reloaded while the Addon Debugger is opened.
|
|
extension = ExtensionTestUtils.loadExtension({
|
|
manifest: {
|
|
applications: {
|
|
gecko: {
|
|
id: "test-reloaded@test.mozilla.com",
|
|
},
|
|
},
|
|
},
|
|
background() {
|
|
browser.test.sendMessage("background.ready");
|
|
},
|
|
});
|
|
|
|
await extension.startup();
|
|
await extension.awaitMessage("background.ready");
|
|
|
|
equal(ExtensionParent.DebugUtils.debugBrowserPromises.size, 1,
|
|
"Got the expected number of requested debug browsers");
|
|
|
|
const newAddonDebugBrowser = await ExtensionParent.DebugUtils
|
|
.getExtensionProcessBrowser(fakeAddonActor);
|
|
|
|
equal(addonDebugBrowser, newAddonDebugBrowser,
|
|
"The existent debugging browser has been reused");
|
|
|
|
equal(newAddonDebugBrowser.isRemoteBrowser, extension.extension.remote,
|
|
"The addon debugging browser has the expected remote type");
|
|
|
|
await ExtensionParent.DebugUtils.releaseExtensionProcessBrowser(fakeAddonActor);
|
|
|
|
equal(ExtensionParent.DebugUtils.debugBrowserPromises.size, 0,
|
|
"All the addon debugging browsers has been released");
|
|
|
|
await extension.unload();
|
|
});
|
|
|
|
add_task(async function testExtensionDebuggingUtilsWithMultipleAddons() {
|
|
let extension = ExtensionTestUtils.loadExtension({
|
|
manifest: {
|
|
applications: {
|
|
gecko: {
|
|
id: "test-addon-1@test.mozilla.com",
|
|
},
|
|
},
|
|
},
|
|
background() {
|
|
browser.test.sendMessage("background.ready");
|
|
},
|
|
});
|
|
let anotherExtension = ExtensionTestUtils.loadExtension({
|
|
manifest: {
|
|
applications: {
|
|
gecko: {
|
|
id: "test-addon-2@test.mozilla.com",
|
|
},
|
|
},
|
|
},
|
|
background() {
|
|
browser.test.sendMessage("background.ready");
|
|
},
|
|
});
|
|
|
|
await extension.startup();
|
|
await extension.awaitMessage("background.ready");
|
|
|
|
await anotherExtension.startup();
|
|
await anotherExtension.awaitMessage("background.ready");
|
|
|
|
const fakeAddonActor = {
|
|
addonId: extension.id,
|
|
};
|
|
|
|
const anotherFakeAddonActor = {
|
|
addonId: anotherExtension.id,
|
|
};
|
|
|
|
const {DebugUtils} = ExtensionParent;
|
|
const debugBrowser = await DebugUtils.getExtensionProcessBrowser(fakeAddonActor);
|
|
const anotherDebugBrowser = await DebugUtils.getExtensionProcessBrowser(anotherFakeAddonActor);
|
|
|
|
const chromeDocument = DebugUtils.hiddenXULWindow.chromeDocument;
|
|
|
|
equal(ExtensionParent.DebugUtils.debugBrowserPromises.size, 2,
|
|
"Got the expected number of debug browsers requested");
|
|
ok(debugBrowser.parentElement === chromeDocument.documentElement,
|
|
"The first debug browser is part of the hiddenXUL chromeDocument");
|
|
ok(anotherDebugBrowser.parentElement === chromeDocument.documentElement,
|
|
"The second debug browser is part of the hiddenXUL chromeDocument");
|
|
|
|
await ExtensionParent.DebugUtils.releaseExtensionProcessBrowser(fakeAddonActor);
|
|
|
|
equal(ExtensionParent.DebugUtils.debugBrowserPromises.size, 1,
|
|
"Got the expected number of debug browsers requested");
|
|
|
|
ok(anotherDebugBrowser.parentElement === chromeDocument.documentElement,
|
|
"The second debug browser is still part of the hiddenXUL chromeDocument");
|
|
|
|
ok(debugBrowser.parentElement == null,
|
|
"The first debug browser has been removed from the hiddenXUL chromeDocument");
|
|
|
|
await ExtensionParent.DebugUtils.releaseExtensionProcessBrowser(anotherFakeAddonActor);
|
|
|
|
ok(anotherDebugBrowser.parentElement == null,
|
|
"The second debug browser has been removed from the hiddenXUL chromeDocument");
|
|
equal(ExtensionParent.DebugUtils.debugBrowserPromises.size, 0,
|
|
"All the addon debugging browsers has been released");
|
|
|
|
await extension.unload();
|
|
await anotherExtension.unload();
|
|
});
|