summaryrefslogtreecommitdiffstats
path: root/devtools/client/debugger/test/mochitest/browser_dbg_cmd-dbg.js
blob: e843d0cd5c8d19b576e10c09195914a03e7f9a3f (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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
/* Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/publicdomain/zero/1.0/ */

/**
 * Tests that the debugger commands work as they should.
 */

const TEST_URI = EXAMPLE_URL + "doc_cmd-dbg.html";

function test() {
  return Task.spawn(function* () {
    let options = yield helpers.openTab(TEST_URI);
    yield helpers.openToolbar(options);

    yield helpers.audit(options, [{
      setup: "dbg open",
      exec: { output: "" }
    }]);

    let [gTab, gDebuggee, gPanel] = yield initDebugger(gBrowser.selectedTab);
    let gDebugger = gPanel.panelWin;
    let gThreadClient = gDebugger.gThreadClient;

    yield helpers.audit(options, [{
      setup: "dbg list",
      exec: { output: /doc_cmd-dbg.html/ }
    }]);

    let button = gDebuggee.document.querySelector("input[type=button]");
    let output = gDebuggee.document.querySelector("input[type=text]");

    let cmd = function (aTyped, aState) {
      return promise.all([
        waitForThreadEvents(gPanel, aState),
        helpers.audit(options, [{ setup: aTyped, exec: { output: "" } }])
      ]);
    };

    let click = function (aElement, aState) {
      return promise.all([
        waitForThreadEvents(gPanel, aState),
        executeSoon(() => EventUtils.sendMouseEvent({ type: "click" }, aElement, gDebuggee))
      ]);
    };

    yield cmd("dbg interrupt", "paused");
    is(gThreadClient.state, "paused", "Debugger is paused.");

    yield cmd("dbg continue", "resumed");
    isnot(gThreadClient.state, "paused", "Debugger has continued.");

    yield click(button, "paused");
    is(gThreadClient.state, "paused", "Debugger is paused again.");

    yield cmd("dbg step in", "paused");
    yield cmd("dbg step in", "paused");
    yield cmd("dbg step in", "paused");
    is(output.value, "step in", "Debugger stepped in.");

    yield cmd("dbg step over", "paused");
    is(output.value, "step over", "Debugger stepped over.");

    yield cmd("dbg step out", "paused");
    is(output.value, "step out", "Debugger stepped out.");

    yield cmd("dbg continue", "paused");
    is(output.value, "dbg continue", "Debugger continued.");

    let closeDebugger = function () {
      let deferred = promise.defer();

      helpers.audit(options, [{
        setup: "dbg close",
        exec: { output: "" }
      }])
      .then(() => {
        let toolbox = gDevTools.getToolbox(options.target);
        if (!toolbox) {
          ok(true, "Debugger is closed.");
          deferred.resolve();
        } else {
          toolbox.on("destroyed", () => {
            ok(true, "Debugger just closed.");
            deferred.resolve();
          });
        }
      });

      return deferred.promise;
    };

    // We close the debugger twice to ensure 'dbg close' doesn't error when
    // toolbox is already closed. See bug 884638 for more info.
    yield closeDebugger();
    yield closeDebugger();
    yield helpers.closeToolbar(options);
    yield helpers.closeTab(options);

  }).then(finish, helpers.handleError);
}