set-breakpoint-after-gc.js 1.76 KB
Newer Older
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 39 40 41 42 43 44 45 46 47 48 49 50 51 52
// 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.');

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') }`;

Protocol.Debugger.enable().then(onDebuggerEnabled);

function onDebuggerEnabled() {
  Protocol.Runtime.enable();
  Protocol.Runtime.onExecutionContextCreated(onExecutionContextCreated);
}

async function onExecutionContextCreated(messageObject) {
  executionContextId = messageObject.params.context.id;
  await testSetBreakpoint(executionContextId, topLevelFunction, 'topLevel.js');
  await testSetBreakpoint(executionContextId, moduleFunction, 'moduleFunc.js');
  InspectorTest.completeTest();
}

async function testSetBreakpoint(executionContextId, func, url) {
  const obj = await Protocol.Runtime.compileScript({
    expression: func,
    sourceURL: url,
    persistScript: true,
    executionContextId: executionContextId
  });
  const scriptId = obj.result.scriptId;
  await Protocol.Runtime.runScript({scriptId});
  await Protocol.Runtime.evaluate({expression: `${callGarbageCollector}`});
  const {result: {locations}} =
      await Protocol.Debugger.setBreakpointByUrl({lineNumber: 0, url});
  InspectorTest.log(`Result of setting breakpoint in ${url}`);
  InspectorTest.log(JSON.stringify(locations));
}