summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/debug/onEnterFrame-async-01.js
blob: 299516264e37e23adebce1d2d0abd63cdb004134 (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
// async functions fire onEnterFrame each time they resume, like generators

let g = newGlobal({newCompartment: true});
g.eval(`
    async function timeout(n) {
        for (let i = 0; i < n; i++) {
            await Promise.resolve(i);
        }
    }
    async function job() {
        let racer = timeout(5);
        await timeout(3);
        await racer;
    }
`);

let dbg = Debugger(g);
let log = "";
let nicknames = ["job", "t5", "t3"];
dbg.onEnterFrame = frame => {
    if (!("nickname" in frame))
        frame.nickname = nicknames.shift() || "FAIL";
    log += "(" + frame.nickname;
    frame.onPop = completion => { log += ")"; };
};

g.job();
drainJobQueue();
assertEq(log,
         "(job(t5)(t3))" +
         "(t5)(t3)".repeat(3) +
         "(t5)(job)(t5)(job)");