blob: cb0cf8f7d7e01c2eac9589febc62a00ae982535b (
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
|
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
const xpcInspector = Cc["@mozilla.org/jsinspector;1"].getService(
Ci.nsIJSInspector
);
add_task(
threadFrontTest(async ({ threadFront, debuggee }) => {
Assert.equal(xpcInspector.eventLoopNestLevel, 0);
const packet = await executeOnNextTickAndWaitForPause(
() => evalCode(debuggee),
threadFront
);
Assert.equal(false, "error" in packet);
Assert.ok("actor" in packet);
Assert.ok("why" in packet);
Assert.equal(packet.why.type, "debuggerStatement");
// Reach around the protocol to check that the debuggee is in the state
// we expect.
Assert.ok(debuggee.a);
Assert.ok(!debuggee.b);
Assert.equal(xpcInspector.eventLoopNestLevel, 1);
// Let the debuggee continue execution.
await threadFront.resume();
// Now make sure that we've run the code after the debugger statement...
Assert.ok(debuggee.b);
Assert.equal(xpcInspector.eventLoopNestLevel, 0);
})
);
function evalCode(debuggee) {
Cu.evalInSandbox(
"var a = true; var b = false; debugger; var b = true;",
debuggee
);
}
|