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
103
104
105
106
107
108
109
|
/* -*- 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 if a warning is shown in the inspector when debugger is paused.
*/
const TAB_URL = EXAMPLE_URL + "doc_inline-script.html";
var gTab, gPanel, gDebugger;
var gTarget, gToolbox;
function test() {
let options = {
source: TAB_URL,
line: 1
};
initDebugger(TAB_URL, options).then(([aTab,, aPanel]) => {
gTab = aTab;
gPanel = aPanel;
gDebugger = gPanel.panelWin;
gTarget = gPanel.target;
gToolbox = gPanel._toolbox;
testPause();
});
}
function testPause() {
gDebugger.gThreadClient.addOneTimeListener("paused", () => {
ok(gDebugger.gThreadClient.paused,
"threadClient.paused has been updated to true.");
gToolbox.once("inspector-selected").then(inspector => {
inspector.once("inspector-updated").then(testNotificationIsUp1);
});
gToolbox.selectTool("inspector");
});
EventUtils.sendMouseEvent({ type: "mousedown" },
gDebugger.document.getElementById("resume"),
gDebugger);
// Evaluate a script to fully pause the debugger
once(gDebugger.gClient, "willInterrupt").then(() => {
evalInTab(gTab, "1+1;");
});
}
function testNotificationIsUp1() {
let notificationBox = gToolbox.getNotificationBox();
let notification = notificationBox.getNotificationWithValue("inspector-script-paused");
ok(notification,
"Inspector notification is present (1).");
gToolbox.once("jsdebugger-selected", testNotificationIsHidden);
gToolbox.selectTool("jsdebugger");
}
function testNotificationIsHidden() {
let notificationBox = gToolbox.getNotificationBox();
let notification = notificationBox.getNotificationWithValue("inspector-script-paused");
ok(!notification,
"Inspector notification is hidden (2).");
gToolbox.once("inspector-selected", testNotificationIsUp2);
gToolbox.selectTool("inspector");
}
function testNotificationIsUp2() {
let notificationBox = gToolbox.getNotificationBox();
let notification = notificationBox.getNotificationWithValue("inspector-script-paused");
ok(notification,
"Inspector notification is present again (3).");
testResume();
}
function testResume() {
gDebugger.gThreadClient.addOneTimeListener("resumed", () => {
ok(!gDebugger.gThreadClient.paused,
"threadClient.paused has been updated to false.");
let notificationBox = gToolbox.getNotificationBox();
let notification = notificationBox.getNotificationWithValue("inspector-script-paused");
ok(!notification,
"Inspector notification was removed once debugger resumed.");
closeDebuggerAndFinish(gPanel);
});
EventUtils.sendMouseEvent({ type: "mousedown" },
gDebugger.document.getElementById("resume"),
gDebugger);
}
registerCleanupFunction(function () {
gTab = null;
gPanel = null;
gDebugger = null;
gTarget = null;
gToolbox = null;
});
|