806352179e
This adds a re-compilation of top level functions in getPossibleBreakpoints if no candidates could be found. This step is necessary as the GC may remove SharedFunctionInfo about top-level functions. Bug: chromium:1137141 Change-Id: I8830438d78751ba318d65f43d790ee98f306a57e Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2696154 Reviewed-by: Leszek Swirski <leszeks@chromium.org> Reviewed-by: Benedikt Meurer <bmeurer@chromium.org> Commit-Queue: Kim-Anh Tran <kimanh@chromium.org> Cr-Commit-Position: refs/heads/master@{#73008}
61 lines
2.1 KiB
JavaScript
61 lines
2.1 KiB
JavaScript
// Copyright 2021 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --allow-natives-syntax
|
|
|
|
let {session, contextGroup, Protocol} = InspectorTest.start(
|
|
'Checks if we keep alive breakpoint information for top-level functions when calling getPossibleBreakpoints.');
|
|
|
|
session.setupScriptMap();
|
|
var executionContextId;
|
|
|
|
const callGarbageCollector = `
|
|
%CollectGarbage("");
|
|
%CollectGarbage("");
|
|
%CollectGarbage("");
|
|
%CollectGarbage("");
|
|
`;
|
|
|
|
const topLevelFunction = `console.log('This is a top level function')`;
|
|
const moduleFunction =
|
|
`function testFunc() { console.log('This is a module function') }`;
|
|
let mixedFunctions = ` function A() {}
|
|
console.log('This is a top level function');
|
|
`;
|
|
|
|
Protocol.Debugger.enable().then(onDebuggerEnabled);
|
|
|
|
function onDebuggerEnabled() {
|
|
Protocol.Runtime.enable();
|
|
Protocol.Runtime.onExecutionContextCreated(onExecutionContextCreated);
|
|
}
|
|
|
|
async function onExecutionContextCreated(messageObject) {
|
|
executionContextId = messageObject.params.context.id;
|
|
await testGetPossibleBreakpoints(
|
|
executionContextId, topLevelFunction, 'topLevel.js');
|
|
await testGetPossibleBreakpoints(
|
|
executionContextId, moduleFunction, 'moduleFunc.js');
|
|
await testGetPossibleBreakpoints(
|
|
executionContextId, mixedFunctions, 'mixedFunctions.js');
|
|
InspectorTest.completeTest();
|
|
}
|
|
|
|
async function testGetPossibleBreakpoints(executionContextId, func, url) {
|
|
const obj = await Protocol.Runtime.compileScript({
|
|
expression: func,
|
|
sourceURL: url,
|
|
persistScript: true,
|
|
executionContextId: executionContextId
|
|
});
|
|
const scriptId = obj.result.scriptId;
|
|
const location = {start: {lineNumber: 0, columnNumber: 0, scriptId}};
|
|
await Protocol.Runtime.runScript({scriptId});
|
|
await Protocol.Runtime.evaluate({expression: `${callGarbageCollector}`});
|
|
const {result: {locations}} =
|
|
await Protocol.Debugger.getPossibleBreakpoints(location);
|
|
InspectorTest.log(`Result of get possible breakpoints in ${url}`);
|
|
InspectorTest.log(JSON.stringify(locations));
|
|
}
|