diff options
Diffstat (limited to 'devtools/client/debugger/test/mochitest/browser_dbg_pause-resume.js')
-rw-r--r-- | devtools/client/debugger/test/mochitest/browser_dbg_pause-resume.js | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/devtools/client/debugger/test/mochitest/browser_dbg_pause-resume.js b/devtools/client/debugger/test/mochitest/browser_dbg_pause-resume.js new file mode 100644 index 000000000..e9aaebe55 --- /dev/null +++ b/devtools/client/debugger/test/mochitest/browser_dbg_pause-resume.js @@ -0,0 +1,91 @@ +/* -*- 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 pausing and resuming in the main loop works properly. + */ + +const TAB_URL = EXAMPLE_URL + "doc_pause-exceptions.html"; + +var gTab, gPanel, gDebugger; +var gResumeButton, gResumeKey, gFrames; + +function test() { + let options = { + source: TAB_URL, + line: 1 + }; + initDebugger(TAB_URL, options).then(([aTab,, aPanel]) => { + gTab = aTab; + gPanel = aPanel; + gDebugger = gPanel.panelWin; + gResumeButton = gDebugger.document.getElementById("resume"); + gResumeKey = gDebugger.document.getElementById("resumeKey"); + gFrames = gDebugger.DebuggerView.StackFrames; + + testPause(); + }); +} + +function testPause() { + is(gDebugger.gThreadClient.paused, false, + "Should be running after starting the test."); + + is(gResumeButton.getAttribute("tooltiptext"), + gDebugger.L10N.getFormatStr("pauseButtonTooltip", + gDebugger.ShortcutUtils.prettifyShortcut(gResumeKey)), + "Button tooltip should be 'pause' when running."); + + gDebugger.gThreadClient.addOneTimeListener("paused", () => { + is(gDebugger.gThreadClient.paused, true, + "Should be paused after an interrupt request."); + + is(gResumeButton.getAttribute("tooltiptext"), + gDebugger.L10N.getFormatStr("resumeButtonTooltip", + gDebugger.ShortcutUtils.prettifyShortcut(gResumeKey)), + "Button tooltip should be 'resume' when paused."); + + is(gFrames.itemCount, 0, + "Should have no frames when paused in the main loop."); + + testResume(); + }); + + EventUtils.sendMouseEvent({ type: "mousedown" }, gResumeButton, gDebugger); + + is(gResumeButton.getAttribute("tooltiptext"), + gDebugger.L10N.getFormatStr("pausePendingButtonTooltip"), + "Button tooltip should be 'waiting for execution' when breaking on nex."); + + // Evaluate a script to fully pause the debugger + once(gDebugger.gClient, "willInterrupt").then(() => { + evalInTab(gTab, "1+1;"); + }); +} + +function testResume() { + gDebugger.gThreadClient.addOneTimeListener("resumed", () => { + is(gDebugger.gThreadClient.paused, false, + "Should be paused after an interrupt request."); + + is(gResumeButton.getAttribute("tooltiptext"), + gDebugger.L10N.getFormatStr("pauseButtonTooltip", + gDebugger.ShortcutUtils.prettifyShortcut(gResumeKey)), + "Button tooltip should be pause when running."); + + closeDebuggerAndFinish(gPanel); + }); + + EventUtils.sendMouseEvent({ type: "mousedown" }, gResumeButton, gDebugger); +} + +registerCleanupFunction(function () { + gTab = null; + gPanel = null; + gDebugger = null; + gResumeButton = null; + gResumeKey = null; + gFrames = null; +}); |