step-into-optimized-blackbox.js 1.27 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
// 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('Tests stepping with blackboxing and inlining');

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

contextGroup.addScript(
`function foo() {
  return "foo";
}
//# sourceURL=foo.js`);

Protocol.Debugger.enable();
Protocol.Debugger.setBlackboxPatterns({ patterns: [ "bar.js" ] });

Protocol.Debugger.onPaused(PerformSteps);
Protocol.Runtime.evaluate({
27 28
  "expression": "%PrepareFunctionForOptimization(bar); bar(); bar(); " +
                "%OptimizeFunctionOnNextCall(bar); bar()"
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
});
Protocol.Runtime.evaluate({ "expression": "debugger; bar();" });

var commands = [ "stepInto", "stepInto" ];

function PerformSteps(message) {
  InspectorTest.log("Paused in");
  var callFrames = message.params.callFrames;
  for (var callFrame of callFrames) {
    InspectorTest.log(
        (callFrame.functionName || "(...)") + ":" + (callFrame.location.lineNumber + 1));
  }
  var command = commands.shift();
  if (!command) {
    InspectorTest.completeTest();
    return;
  }
  Protocol.Debugger[command]();
}