v8/test/inspector/debugger/step-into-optimized-blackbox.js
Ross McIlroy 69a71cba40 [Test] Add PrepareForOptimization to inspector tests
Bug: v8:8801, v8:8394
Change-Id: I7f27cb0a9dcbdd1ba0e3f90735472408c22185e1
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1593304
Commit-Queue: Ross McIlroy <rmcilroy@chromium.org>
Commit-Queue: Mythri Alle <mythria@chromium.org>
Auto-Submit: Ross McIlroy <rmcilroy@chromium.org>
Reviewed-by: Mythri Alle <mythria@chromium.org>
Cr-Commit-Position: refs/heads/master@{#61182}
2019-05-02 16:01:41 +00:00

48 lines
1.3 KiB
JavaScript

// 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({
"expression": "%PrepareFunctionForOptimization(bar); bar(); bar(); " +
"%OptimizeFunctionOnNextCall(bar); bar()"
});
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]();
}