Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(23)

Side by Side Diff: test/inspector/debugger/wasm-source.js

Issue 2492123003: [inspector] Add test case for wasm source (Closed)
Patch Set: Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | test/inspector/debugger/wasm-source-expected.txt » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2016 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // Flags: --expose-wasm
6
7 load('test/mjsunit/wasm/wasm-constants.js');
8 load('test/mjsunit/wasm/wasm-module-builder.js');
9
10 var builder = new WasmModuleBuilder();
11
12 var imported_idx = builder.addImport("func", kSig_v_v);
13
14 var call_imported_idx = builder.addFunction("call_func", kSig_v_v)
15 .addBody([kExprCallFunction, imported_idx])
16 .index;
17
18 var sig_index = builder.addType(kSig_v_v);
19
20 builder.addFunction('main', kSig_v_v)
21 .addBody([
22 kExprBlock, kAstStmt, kExprI32Const, 0, kExprCallIndirect, sig_index,
23 kTableZero, kExprEnd
24 ])
25 .exportAs('main');
26
27 builder.appendToTable([call_imported_idx]);
28
29 var module_bytes = builder.toArray();
30
31 function testFunction(bytes) {
32 function call_debugger() {
33 debugger;
34 }
35
36 var buffer = new ArrayBuffer(bytes.length);
37 var view = new Uint8Array(buffer);
38 for (var i = 0; i < bytes.length; i++) {
39 view[i] = bytes[i] | 0;
40 }
41
42 var module = new WebAssembly.Module(buffer);
43 var instance = new WebAssembly.Instance(module, {func: call_debugger});
44
45 instance.exports.main();
46 }
47
48 InspectorTest.addScript(testFunction.toString());
49 InspectorTest.addScript('var module_bytes = ' + JSON.stringify(module_bytes));
50
51 Protocol.Debugger.enable();
52 Protocol.Debugger.onPaused(handleDebuggerPaused);
53 InspectorTest.log('Check that inspector gets disassembled wasm code');
54 Protocol.Runtime.evaluate({'expression': 'testFunction(module_bytes)'});
55
56 function handleDebuggerPaused(messageObject)
57 {
58 InspectorTest.log('Paused on debugger!');
59 var frames = messageObject.params.callFrames;
60 InspectorTest.log('Number of frames: ' + frames.length);
61 function next(frame_id) {
62 if (frame_id == frames.length) {
63 InspectorTest.log('Finished.');
64 InspectorTest.completeTest();
65 }
66 Protocol.Debugger
67 .getScriptSource({scriptId: frames[frame_id].location.scriptId})
68 .then((sourceMessage) => {
kozy 2016/11/15 23:10:53 Please extract this arrow function to real one, we
Clemens Hammacher 2016/11/16 11:58:01 Thanks, that looks much nicer indeed. I have to wo
69 if (sourceMessage.error)
70 InspectorTest.logObject(sourceMessage);
71 var text = sourceMessage.result.scriptSource;
72 var line_nr = frames[frame_id].location.lineNumber;
73 var line = text.split('\n')[line_nr];
74 InspectorTest.log('[' + frame_id + '] ' + line);
75 next(frame_id + 1);
76 });
77 }
78 next(0);
79 }
OLDNEW
« no previous file with comments | « no previous file | test/inspector/debugger/wasm-source-expected.txt » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698