v8/test/mjsunit/wasm/frame-inspection.js
titzer 28392ab196 [wasm] Master CL for Binary 0xC changes.
[0xC] Convert to stack machine semantics.
[0xC] Use section codes instead of names.
[0xC] Add elements section decoding.
[0xC] Decoding of globals section.
[0xC] Decoding of memory section.
[0xC] Decoding of imports section.
[0xC] Decoding of exports section.
[0xC] Decoding of data section.
[0xC] Remove CallImport bytecode.
[0xC] Function bodies have an implicit block.
[0xC] Remove the bottom label from loops.
[0xC] Add signatures to blocks.
[0xC] Remove arities from branches.
Add tests for init expression decoding.
Rework compilation of import wrappers and how they are patched.
Rework function indices in debugging.
Fix ASM->WASM builder for stack machine.
Reorganize asm.js foreign functions due to import indices change.

R=ahaas@chromium.org,rossberg@chromium.org,bradnelson@chromium.org
BUG=chromium:575167
LOG=Y

Committed: https://crrev.com/76eb976a67273b8c03c744f64ad850b0432554b9
Review-Url: https://codereview.chromium.org/2345593003
Cr-Original-Commit-Position: refs/heads/master@{#39678}
Cr-Commit-Position: refs/heads/master@{#39795}
2016-09-27 20:46:30 +00:00

75 lines
2.2 KiB
JavaScript

// Copyright 2016 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: --expose-wasm --expose-debug-as debug
load("test/mjsunit/wasm/wasm-constants.js");
load("test/mjsunit/wasm/wasm-module-builder.js");
Debug = debug.Debug
var exception = null;
var break_count = 0;
const expected_num_frames = 5;
const expected_wasm_frames = [false, true, true, false, false];
const expected_wasm_positions = [0, 1, 2, 0, 0];
const expected_function_names = ["call_debugger", "wasm_2", "wasm_1", "testFrameInspection", ""];
function listener(event, exec_state, event_data, data) {
if (event != Debug.DebugEvent.Break) return;
++break_count;
try {
var break_id = exec_state.break_id;
var frame_count = exec_state.frameCount();
assertEquals(expected_num_frames, frame_count);
for (var i = 0; i < frame_count; ++i) {
var frame = exec_state.frame(i);
// wasm frames have unresolved function, others resolved ones.
assertEquals(expected_wasm_frames[i], !frame.func().resolved());
assertEquals(expected_function_names[i], frame.func().name());
if (expected_wasm_frames[i]) {
var script = frame.details().script();
assertNotNull(script);
assertEquals(expected_wasm_positions[i], frame.details().sourcePosition());
var loc = script.locationFromPosition(frame.details().sourcePosition());
assertEquals(expected_wasm_positions[i], loc.column);
assertEquals(expected_wasm_positions[i], loc.position);
}
}
} catch (e) {
exception = e;
}
};
var builder = new WasmModuleBuilder();
// wasm_1 calls wasm_2 on offset 2.
// wasm_2 calls call_debugger on offset 1.
builder.addImport("func", kSig_v_v);
builder.addFunction("wasm_1", kSig_v_v)
.addBody([kExprNop, kExprCallFunction, 2])
.exportAs("main");
builder.addFunction("wasm_2", kSig_v_v)
.addBody([kExprCallFunction, 0]);
function call_debugger() {
debugger;
}
var module = builder.instantiate({func: call_debugger});
(function testFrameInspection() {
Debug.setListener(listener);
module.exports.main();
Debug.setListener(null);
assertEquals(1, break_count);
if (exception) throw exception;
})();