76e849d2e5988e4e1c372d49413150d5a158fd63
[WebKit-https.git] / JSTests / wasm / function-tests / stack-trace.js
1 import Builder from '../Builder.js'
2 import * as assert from '../assert.js'
3
4 const builder = (new Builder())
5     .Type().End()
6     .Import()
7         .Function("imp", "f", { params: [], ret: "void" })
8     .End()
9     .Function().End()
10     .Export().Function("entry").End()
11     .Code()
12          // idx 1
13         .Function("entry", {params: []})
14             .Call(3)
15         .End()
16         // idx 2
17         .Function({params: []})
18             .Call(4)
19         .End()
20         // idx 3
21         .Function({params: []})
22             .Call(2)
23         .End()
24         // idx 4
25         .Function({params: []})
26             .Call(0)
27         .End()
28     .End();
29
30 let stacktrace;
31 let imp = () => {
32     stacktrace = (new Error).stack;
33 }
34
35
36 const bin = builder.WebAssembly().get();
37 const module = new WebAssembly.Module(bin);
38 let instance = new WebAssembly.Instance(module, {imp: {f: imp}});
39 assert.falsy(stacktrace);
40 for (let i = 0; i < 10000; ++i) {
41     instance.exports.entry();
42     assert.truthy(stacktrace);
43     stacktrace = stacktrace.split("\n");
44     assert.truthy(stacktrace[0].indexOf("imp") !== -1); // the arrow function import named "imp".
45     assert.eq(stacktrace[1], "wasm-stub@[wasm code]"); // the wasm->js stub
46     assert.eq(stacktrace[2], "<?>.wasm-function[4]@[wasm code]");
47     assert.eq(stacktrace[3], "<?>.wasm-function[2]@[wasm code]");
48     assert.eq(stacktrace[4], "<?>.wasm-function[3]@[wasm code]");
49     assert.eq(stacktrace[5], "<?>.wasm-function[1]@[wasm code]");
50     assert.eq(stacktrace[6], "wasm-stub@[wasm code]"); // wasm entry
51
52     stacktrace = null;
53 }