forked from mirrors/gecko-dev
This used to be a node package. Let's make it become regular commonjs devtools modules. This will make it trivial to migrate this to ES Modules. Also possibly make this code become the unique layer in m-c on top of the source-map package. We no longer use webpack to build the two bundles (index.js and worker.js), instead, we are using the toolkit worker loader (require.js) in order to load all this code without any build step. As this is no longer a node package, I removed node-specific modules (assertRoot/wasmAsset) and simplify the definition of wasm file URIs as they are now fixed. Also moving the debugger to load internal "devtools/client/shared/source-map/source-map.js" module in jest as running the Web Worker instantiated by source-map/index.js is too complex. Differential Revision: https://phabricator.services.mozilla.com/D159115
67 lines
2.5 KiB
JavaScript
67 lines
2.5 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
"use strict";
|
|
|
|
/**
|
|
* This test records the number of modules loaded by DevTools, as well as the total count
|
|
* of characters in those modules, when opening the debugger. These metrics are
|
|
* retrieved by perfherder via logs.
|
|
*/
|
|
|
|
const TEST_URL =
|
|
"data:text/html;charset=UTF-8,<div>Debugger modules load test</div>";
|
|
|
|
add_task(async function() {
|
|
// Disable randomly spawning processes during tests
|
|
await pushPref("dom.ipc.processPrelaunch.enabled", false);
|
|
|
|
const toolbox = await openNewTabAndToolbox(TEST_URL, "jsdebugger");
|
|
const toolboxBrowserLoader = toolbox.win.getBrowserLoaderForWindow();
|
|
|
|
// Retrieve the browser loader dedicated to the Debugger.
|
|
const panel = toolbox.getCurrentPanel();
|
|
const debuggerLoader = panel.panelWin.getBrowserLoaderForWindow();
|
|
|
|
const loaders = [
|
|
loader.loader,
|
|
toolboxBrowserLoader.loader,
|
|
debuggerLoader.loader,
|
|
];
|
|
|
|
const allowedDupes = [
|
|
"@loader/unload.js",
|
|
"@loader/options.js",
|
|
"resource://devtools/client/shared/vendor/fluent-react.js",
|
|
"resource://devtools/client/shared/vendor/react-dom.js",
|
|
"resource://devtools/client/shared/vendor/react.js",
|
|
"resource://devtools/client/shared/vendor/react-prop-types.js",
|
|
"resource://devtools/client/shared/vendor/react-dom-factories.js",
|
|
"resource://devtools/client/shared/vendor/react-redux.js",
|
|
"resource://devtools/client/shared/vendor/redux.js",
|
|
"resource://devtools/client/shared/redux/subscriber.js",
|
|
"resource://devtools/client/shared/worker-utils.js",
|
|
"resource://devtools/client/debugger/src/workers/parser/index.js",
|
|
|
|
"resource://devtools/client/shared/source-map-loader/index.js",
|
|
"resource://devtools/client/shared/source-map-loader/utils/index.js",
|
|
"resource://devtools/client/shared/vendor/md5.js",
|
|
|
|
"resource://devtools/client/shared/components/menu/MenuButton.js",
|
|
"resource://devtools/client/shared/components/menu/MenuItem.js",
|
|
"resource://devtools/client/shared/components/menu/MenuList.js",
|
|
];
|
|
runDuplicatedModulesTest(loaders, allowedDupes);
|
|
|
|
runMetricsTest({
|
|
filterString: "devtools/client/debugger",
|
|
loaders,
|
|
panelName: "debugger",
|
|
});
|
|
|
|
// See Bug 1637793 and Bug 1621337.
|
|
// Ideally the debugger should only resolve when the worker targets have been
|
|
// retrieved, which should be fixed by Bug 1621337 or a followup.
|
|
info("Wait for all pending requests to settle on the DevToolsClient");
|
|
await toolbox.commands.client.waitForRequestsToSettle();
|
|
});
|