fune/js/xpconnect/tests/chrome/test_onGarbageCollection.html
Ted Campbell 69dfb519c2 Bug 1790912 - Use globalThis instead of this with jsdebugger.jsm. r=jandem,ochameau
Use 'globalThis' instead of 'this' when trying to attach a debugger to the
current global to avoid subtle footguns with the varied definitions of 'this'.
The debugger interface needs a true GlobalObject so this is much clearer. In
particular, this is a problem in test_nativewrappers.js when the test runs in
strict mode since the 'this' in the test function is no long implicitly the
global.

Differential Revision: https://phabricator.services.mozilla.com/D157544
2022-09-25 09:03:33 +00:00

48 lines
1.4 KiB
HTML

<!doctype html>
<html>
<head>
<title>Bug 1150253 - Sanity test for the SpiderMonkey Debugger API's onGarbageCollection hook</title>
<script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js">
</script>
</head>
<body xmlns="http://www.w3.org/1999/xhtml">
<a href="https://bugzilla.mozilla.org/show_bug.cgi?id=1150253"
target="_blank">Mozilla Bug 1150253</a>
<script type="application/javascript">
SimpleTest.waitForExplicitFinish();
const { gc } = Cu.getJSTestingFunctions();
// Instantiate `Debugger` in a sandbox as Debugger requires to be created
// in a compartment different than the debuggee.
let sandbox = Cu.Sandbox(
Components.Constructor("@mozilla.org/systemprincipal;1", "nsIPrincipal")(),
{
freshCompartment: true,
wantGlobalProperties: ["ChromeUtils"],
}
);
Cu.evalInSandbox(`
const { addDebuggerToGlobal } = ChromeUtils.import(
'resource://gre/modules/jsdebugger.jsm'
);
addDebuggerToGlobal(globalThis);
`, sandbox
);
const dbg = new sandbox.Debugger(this);
dbg.memory.onGarbageCollection = function (data) {
// Don't keep calling this hook after we finish.
dbg.memory.onGarbageCollection = undefined;
dbg.removeAllDebuggees();
ok(data, "The onGarbageCollection hook was fired.");
SimpleTest.finish();
};
gc();
</script>
</body>
</html>