eb36a7dbcf
If the imported wasm function is being debugged (i.e. redirects to the interpreter), call it via the JS_TO_WASM stub, such that we can disable the breakpoint later by patching the exported function. This also contains a drive-by fix in wasm-translation.cc (for the case that all known positions are bigger than the requested one). R=titzer@chromium.org, kozyatinskiy@chromium.org BUG=v8:5971, v8:5822 Review-Url: https://codereview.chromium.org/2720813002 Cr-Commit-Position: refs/heads/master@{#43583}
33 lines
1.1 KiB
JavaScript
33 lines
1.1 KiB
JavaScript
// Copyright 2017 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.
|
|
|
|
InspectorTest.log('Checks possible break locations.');
|
|
|
|
InspectorTest.setupScriptMap();
|
|
Protocol.Debugger.onPaused(message => {
|
|
var frames = message.params.callFrames;
|
|
if (frames.length === 1) {
|
|
Protocol.Debugger.stepInto();
|
|
return;
|
|
}
|
|
var scriptId = frames[0].location.scriptId;
|
|
InspectorTest.log('break at:');
|
|
InspectorTest.logSourceLocation(frames[0].location)
|
|
.then(() => Protocol.Debugger.stepInto());
|
|
});
|
|
|
|
InspectorTest.loadScript('test/inspector/debugger/resources/break-locations.js');
|
|
|
|
Protocol.Debugger.enable();
|
|
Protocol.Runtime.evaluate({ expression: 'Object.keys(this).filter(name => name.indexOf(\'test\') === 0)', returnByValue: true })
|
|
.then(runTests);
|
|
|
|
function runTests(message) {
|
|
var tests = message.result.result.value;
|
|
InspectorTest.runTestSuite(tests.map(test => eval(`(function ${test}(next) {
|
|
Protocol.Runtime.evaluate({ expression: 'debugger; ${test}()', awaitPromise: ${test.indexOf('testPromise') === 0}})
|
|
.then(next);
|
|
})`)));
|
|
}
|