blob: e7ecab1754ed8bafd41857f3d768fde9aef08316 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
// A Debugger can {return:} from the first onEnterFrame for an async function.
// (The exact behavior is undocumented; we're testing that it doesn't crash.)
ignoreUnhandledRejections();
let g = newGlobal({newCompartment: true});
g.eval(`async function f(x) { await x; return "ponies"; }`);
g.eval(`async function f2(x) { await x; return "moar ponies"; }`);
let dbg = new Debugger;
let gw = dbg.addDebuggee(g);
let hits = 0;
let resumption = undefined;
let savedAsyncGen = undefined;
dbg.onEnterFrame = frame => {
if (frame.type == "call" && frame.callee.name === "f2") {
frame.onPop = completion => {
if (savedAsyncGen === undefined) {
savedAsyncGen = completion.return;
}
};
}
if (frame.type == "call" && frame.callee.name === "f") {
frame.onPop = completion => {
hits++;
};
return {return: savedAsyncGen};
}
};
let p2 = g.f2(0);
let p = g.f(0);
assertEq(hits, 1);
drainJobQueue();
assertEq(hits, 1);
let pw2 = gw.makeDebuggeeValue(p2);
assertEq(pw2.isPromise, true);
assertEq(pw2.promiseState, "fulfilled");
assertEq(pw2.promiseValue, "moar ponies");
let pw = gw.makeDebuggeeValue(p);
assertEq(pw.isPromise, true);
assertEq(pw.promiseState, "fulfilled");
assertEq(pw.promiseValue, "moar ponies");
|