pause-inside-blackboxed-optimized.js 1023 Bytes
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
// Copyright 2018 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 pause inside blackboxed optimized function call.');

contextGroup.addScript(`
  function foo() {
    return 1 + bar();
  }
  //# sourceURL=framework.js
`);

contextGroup.addScript(`
  function bar() {
    return 2;
  }
21
  %PrepareFunctionForOptimization(foo);
22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
  foo();
  foo();
  %OptimizeFunctionOnNextCall(foo);
  foo();
  //# sourceURL=test.js
`);

(async function test(){
  Protocol.Debugger.enable();
  Protocol.Debugger.setBlackboxPatterns({patterns: ['framework\.js']});
  Protocol.Runtime.evaluate({expression: `
  inspector.callWithScheduledBreak(foo, 'break', '');
  //# sourceURL=expr.js
  `});
  const {params:{callFrames}} = await Protocol.Debugger.oncePaused();
  session.logCallFrames(callFrames);
  InspectorTest.completeTest();
})();