summaryrefslogtreecommitdiffstats
path: root/devtools/server/tests/xpcshell/test_conditional_breakpoint-03.js
blob: 7b26614a2c215f26f06e1c57a83cc27ebaf84f2a (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
50
51
52
53
54
55
56
57
58
59
60
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

/**
 * If pauseOnExceptions is checked, when condition throws,
 * make sure conditional breakpoint pauses.
 */

add_task(
  threadFrontTest(async ({ threadFront, debuggee, commands }) => {
    const packet1 = await executeOnNextTickAndWaitForPause(
      () => evalCode(debuggee),
      threadFront
    );

    const source = await getSourceById(threadFront, packet1.frame.where.actor);

    await commands.threadConfigurationCommand.updateConfiguration({
      pauseOnExceptions: true,
      ignoreCaughtExceptions: false,
    });
    const location = { sourceUrl: source.url, line: 3 };
    threadFront.setBreakpoint(location, { condition: "throw new Error()" });

    // Continue until the breakpoint is hit.
    const packet2 = await resumeAndWaitForPause(threadFront);

    // Check the return value.
    Assert.equal(packet2.why.type, "exception");
    Assert.equal(packet2.frame.where.line, 1);

    // Step over twice.
    await stepOver(threadFront);
    const packet3 = await stepOver(threadFront);

    // Check the return value.
    Assert.equal(packet3.why.type, "breakpointConditionThrown");
    Assert.equal(packet3.frame.where.line, 3);

    // Remove the breakpoint.
    await threadFront.removeBreakpoint(location);
    await threadFront.resume();
  })
);

function evalCode(debuggee) {
  /* eslint-disable */
  Cu.evalInSandbox(
    "debugger;\n" + // line 1
      "var a = 1;\n" + // line 2
      "var b = 2;\n", // line 3
    debuggee,
    "1.8",
    "test.js",
    1
  );
  /* eslint-enable */
}