v8/test/inspector/debugger/wasm-memory-names.js
Kim-Anh Tran f21291bc41 [wasm][debug] Clean up inspector tests
Extract commonly used instantiate() and evalWithUrl() functions.

Bug: chromium:1093165
Change-Id: I14f8b49d556bc70d2092a80b41c5bbf678efd1a9
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2245599
Commit-Queue: Kim-Anh Tran <kimanh@chromium.org>
Reviewed-by: Clemens Backes <clemensb@chromium.org>
Reviewed-by: Benedikt Meurer <bmeurer@chromium.org>
Cr-Commit-Position: refs/heads/master@{#68356}
2020-06-16 08:35:09 +00:00

119 lines
3.5 KiB
JavaScript

// Copyright 2020 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.
utils.load('test/inspector/wasm-inspector-test.js');
let {session, contextGroup, Protocol} =
InspectorTest.start('Test wasm memory names');
let func;
// No name memory.
function createModuleBytesUnnamedMemory() {
let builder = new WasmModuleBuilder();
builder.addMemory(1, 1);
func = builder.addFunction('main', kSig_i_i)
.addBody([kExprI32Const, 0, kExprI32LoadMem, 0, 0])
.exportAs('main');
return JSON.stringify(builder.toArray());
}
// Exported memory.
function createModuleBytesExportedMemory() {
let builder = new WasmModuleBuilder();
var memory = builder.addMemory(1, 1);
builder.addExportOfKind('exported_memory', kExternalMemory);
func = builder.addFunction('main', kSig_i_i)
.addBody([kExprI32Const, 0, kExprI32LoadMem, 0, 0])
.exportAs('main');
return JSON.stringify(builder.toArray());
}
// Imported memory.
function createModuleBytesImportedMemory() {
let builder = new WasmModuleBuilder();
builder.addImportedMemory('module_name', 'imported_mem', 0, 1);
func = builder.addFunction('main', kSig_i_i)
.addBody([kExprI32Const, 0, kExprI32LoadMem, 0, 0])
.exportAs('main');
return JSON.stringify(builder.toArray());
}
function createInstance(moduleBytes) {
let module = new WebAssembly.Module((new Uint8Array(moduleBytes)).buffer);
let memory = new WebAssembly.Memory({initial: 1, maximum: 1});
instance =
new WebAssembly.Instance(module, {module_name: {imported_mem: memory}});
}
async function logMemoryName(msg, Protocol) {
let callFrames = msg.params.callFrames;
InspectorTest.log('Paused in debugger.');
let scopeChain = callFrames[0].scopeChain;
for (let scope of scopeChain) {
if (scope.type != 'module') continue;
let moduleObjectProps = (await Protocol.Runtime.getProperties({
'objectId': scope.object.objectId
})).result.result;
for (let prop of moduleObjectProps) {
if (prop.name == 'instance') continue;
InspectorTest.log(`name: ${prop.name}`);
}
}
}
async function check(moduleBytes) {
Protocol.Runtime.evaluate({
expression: `
createInstance(${moduleBytes});`
});
InspectorTest.log('Waiting for wasm script to be parsed.');
let scriptId;
while (true) {
let msg = await Protocol.Debugger.onceScriptParsed();
if (msg.params.url.startsWith('wasm://')) {
scriptId = msg.params.scriptId;
break;
}
}
InspectorTest.log('Setting breakpoint in wasm.');
await Protocol.Debugger.setBreakpoint(
{location: {scriptId, lineNumber: 0, columnNumber: func.body_offset}});
InspectorTest.log('Running main.');
Protocol.Runtime.evaluate({expression: 'instance.exports.main()'});
let msg = await Protocol.Debugger.oncePaused();
await logMemoryName(msg, Protocol);
await Protocol.Debugger.resume();
InspectorTest.log('Finished.');
}
contextGroup.addScript(`
let instance;
${createInstance.toString()}`);
(async function test() {
try {
Protocol.Debugger.enable();
await check(createModuleBytesUnnamedMemory());
await check(createModuleBytesExportedMemory());
await check(createModuleBytesImportedMemory());
} catch (exc) {
InspectorTest.log(`Failed with exception: ${exc}.`);
} finally {
InspectorTest.completeTest();
}
})();