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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
/* eslint-disable max-nested-callbacks */
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
/**
* Bug 925269 - Verify that debugger statements are skipped
* if there is a falsey conditional breakpoint at the same location.
*/
add_task(
threadFrontTest(async props => {
await testBreakpointsAndDebuggerStatements(props);
})
);
async function testBreakpointsAndDebuggerStatements({ commands, threadFront }) {
commands.scriptCommand.execute(
`function foo(stop) {
debugger;
debugger;
debugger;
}
foo();
//# sourceURL=http://example.com/testBreakpointsAndDebuggerStatements.js`
);
threadFront.setBreakpoint(
{
sourceUrl: "http://example.com/testBreakpointsAndDebuggerStatements.js",
line: 3,
column: 6,
},
{ condition: "false" }
);
await performActions(threadFront, [
[
"paused at first debugger statement",
{ line: 2, type: "debuggerStatement" },
"resume",
],
[
"pause at the third debugger statement",
{ line: 4, type: "debuggerStatement" },
"resume",
],
]);
}
async function performActions(threadFront, actions) {
for (const action of actions) {
await performAction(threadFront, action);
}
}
async function performAction(threadFront, [description, result, action]) {
info(description);
const packet = await waitForEvent(threadFront, "paused");
Assert.equal(packet.frame.where.line, result.line);
Assert.equal(packet.why.type, result.type);
await threadFront[action]();
}
|