michael@0: /* Any copyright is dedicated to the Public Domain. michael@0: http://creativecommons.org/publicdomain/zero/1.0/ */ michael@0: michael@0: /** michael@0: * Make sure that reloading a page with a breakpoint set does not cause it to michael@0: * fire more than once. michael@0: */ michael@0: michael@0: const TAB_URL = EXAMPLE_URL + "doc_included-script.html"; michael@0: const SOURCE_URL = EXAMPLE_URL + "code_location-changes.js"; michael@0: michael@0: let gTab, gDebuggee, gPanel, gDebugger; michael@0: let gEditor, gSources; michael@0: michael@0: function test() { michael@0: initDebugger(TAB_URL).then(([aTab, aDebuggee, aPanel]) => { michael@0: gTab = aTab; michael@0: gDebuggee = aDebuggee; michael@0: gPanel = aPanel; michael@0: gDebugger = gPanel.panelWin; michael@0: gEditor = gDebugger.DebuggerView.editor; michael@0: gSources = gDebugger.DebuggerView.Sources; michael@0: michael@0: waitForSourceAndCaretAndScopes(gPanel, ".html", 17).then(addBreakpoint); michael@0: gDebuggee.runDebuggerStatement(); michael@0: }); michael@0: } michael@0: michael@0: function addBreakpoint() { michael@0: waitForSourceAndCaret(gPanel, ".js", 5).then(() => { michael@0: ok(true, michael@0: "Switched to the desired function when adding a breakpoint " + michael@0: "but not passing { noEditorUpdate: true } as an option."); michael@0: michael@0: testResume(); michael@0: }); michael@0: michael@0: gPanel.addBreakpoint({ url: SOURCE_URL, line: 5 }); michael@0: } michael@0: michael@0: function testResume() { michael@0: is(gDebugger.gThreadClient.state, "paused", michael@0: "The breakpoint wasn't hit yet (1)."); michael@0: is(gSources.selectedValue, SOURCE_URL, michael@0: "The currently shown source is incorrect (1)."); michael@0: ok(isCaretPos(gPanel, 5), michael@0: "The source editor caret position is incorrect (1)."); michael@0: michael@0: gDebugger.gThreadClient.resume(testClick); michael@0: } michael@0: michael@0: function testClick() { michael@0: isnot(gDebugger.gThreadClient.state, "paused", michael@0: "The breakpoint wasn't hit yet (2)."); michael@0: is(gSources.selectedValue, SOURCE_URL, michael@0: "The currently shown source is incorrect (2)."); michael@0: ok(isCaretPos(gPanel, 5), michael@0: "The source editor caret position is incorrect (2)."); michael@0: michael@0: gDebugger.gThreadClient.addOneTimeListener("paused", (aEvent, aPacket) => { michael@0: is(aPacket.why.type, "breakpoint", michael@0: "Execution has advanced to the breakpoint."); michael@0: isnot(aPacket.why.type, "debuggerStatement", michael@0: "The breakpoint was hit before the debugger statement."); michael@0: michael@0: ensureCaretAt(gPanel, 5, 1, true).then(afterBreakpointHit); michael@0: }); michael@0: michael@0: EventUtils.sendMouseEvent({ type: "click" }, michael@0: gDebuggee.document.querySelector("button"), michael@0: gDebuggee); michael@0: } michael@0: michael@0: function afterBreakpointHit() { michael@0: is(gDebugger.gThreadClient.state, "paused", michael@0: "The breakpoint was hit (3)."); michael@0: is(gSources.selectedValue, SOURCE_URL, michael@0: "The currently shown source is incorrect (3)."); michael@0: ok(isCaretPos(gPanel, 5), michael@0: "The source editor caret position is incorrect (3)."); michael@0: michael@0: gDebugger.gThreadClient.addOneTimeListener("paused", (aEvent, aPacket) => { michael@0: is(aPacket.why.type, "debuggerStatement", michael@0: "Execution has advanced to the next line."); michael@0: isnot(aPacket.why.type, "breakpoint", michael@0: "No ghost breakpoint was hit."); michael@0: michael@0: ensureCaretAt(gPanel, 6, 1, true).then(afterDebuggerStatementHit); michael@0: }); michael@0: michael@0: gDebugger.gThreadClient.resume(); michael@0: } michael@0: michael@0: function afterDebuggerStatementHit() { michael@0: is(gDebugger.gThreadClient.state, "paused", michael@0: "The debugger statement was hit (4)."); michael@0: is(gSources.selectedValue, SOURCE_URL, michael@0: "The currently shown source is incorrect (4)."); michael@0: ok(isCaretPos(gPanel, 6), michael@0: "The source editor caret position is incorrect (4)."); michael@0: michael@0: promise.all([ michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.NEW_SOURCE), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.SOURCES_ADDED), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.SOURCE_SHOWN), michael@0: reloadActiveTab(gPanel, gDebugger.EVENTS.BREAKPOINT_SHOWN) michael@0: ]).then(testClickAgain); michael@0: } michael@0: michael@0: function testClickAgain() { michael@0: isnot(gDebugger.gThreadClient.state, "paused", michael@0: "The breakpoint wasn't hit yet (5)."); michael@0: is(gSources.selectedValue, SOURCE_URL, michael@0: "The currently shown source is incorrect (5)."); michael@0: ok(isCaretPos(gPanel, 1), michael@0: "The source editor caret position is incorrect (5)."); michael@0: michael@0: gDebugger.gThreadClient.addOneTimeListener("paused", (aEvent, aPacket) => { michael@0: is(aPacket.why.type, "breakpoint", michael@0: "Execution has advanced to the breakpoint."); michael@0: isnot(aPacket.why.type, "debuggerStatement", michael@0: "The breakpoint was hit before the debugger statement."); michael@0: michael@0: ensureCaretAt(gPanel, 5, 1, true).then(afterBreakpointHitAgain); michael@0: }); michael@0: michael@0: EventUtils.sendMouseEvent({ type: "click" }, michael@0: gDebuggee.document.querySelector("button"), michael@0: gDebuggee); michael@0: } michael@0: michael@0: function afterBreakpointHitAgain() { michael@0: is(gDebugger.gThreadClient.state, "paused", michael@0: "The breakpoint was hit (6)."); michael@0: is(gSources.selectedValue, SOURCE_URL, michael@0: "The currently shown source is incorrect (6)."); michael@0: ok(isCaretPos(gPanel, 5), michael@0: "The source editor caret position is incorrect (6)."); michael@0: michael@0: gDebugger.gThreadClient.addOneTimeListener("paused", (aEvent, aPacket) => { michael@0: is(aPacket.why.type, "debuggerStatement", michael@0: "Execution has advanced to the next line."); michael@0: isnot(aPacket.why.type, "breakpoint", michael@0: "No ghost breakpoint was hit."); michael@0: michael@0: ensureCaretAt(gPanel, 6, 1, true).then(afterDebuggerStatementHitAgain); michael@0: }); michael@0: michael@0: gDebugger.gThreadClient.resume(); michael@0: } michael@0: michael@0: function afterDebuggerStatementHitAgain() { michael@0: is(gDebugger.gThreadClient.state, "paused", michael@0: "The debugger statement was hit (7)."); michael@0: is(gSources.selectedValue, SOURCE_URL, michael@0: "The currently shown source is incorrect (7)."); michael@0: ok(isCaretPos(gPanel, 6), michael@0: "The source editor caret position is incorrect (7)."); michael@0: michael@0: showSecondSource(); michael@0: } michael@0: michael@0: function showSecondSource() { michael@0: gDebugger.once(gDebugger.EVENTS.SOURCE_SHOWN, () => { michael@0: is(gEditor.getText().indexOf("debugger"), 447, michael@0: "The correct source is shown in the source editor.") michael@0: is(gEditor.getBreakpoints().length, 0, michael@0: "No breakpoints should be shown for the second source."); michael@0: michael@0: ensureCaretAt(gPanel, 1, 1, true).then(showFirstSourceAgain); michael@0: }); michael@0: michael@0: EventUtils.sendMouseEvent({ type: "mousedown" }, michael@0: gDebugger.document.querySelectorAll(".side-menu-widget-item-contents")[1], michael@0: gDebugger); michael@0: } michael@0: michael@0: function showFirstSourceAgain() { michael@0: gDebugger.once(gDebugger.EVENTS.SOURCE_SHOWN, () => { michael@0: is(gEditor.getText().indexOf("debugger"), 148, michael@0: "The correct source is shown in the source editor.") michael@0: is(gEditor.getBreakpoints().length, 1, michael@0: "One breakpoint should be shown for the first source."); michael@0: michael@0: ensureCaretAt(gPanel, 6, 1, true).then(() => resumeDebuggerThenCloseAndFinish(gPanel)); michael@0: }); michael@0: michael@0: EventUtils.sendMouseEvent({ type: "mousedown" }, michael@0: gDebugger.document.querySelectorAll(".side-menu-widget-item-contents")[0], michael@0: gDebugger); michael@0: } michael@0: michael@0: registerCleanupFunction(function() { michael@0: gTab = null; michael@0: gDebuggee = null; michael@0: gPanel = null; michael@0: gDebugger = null; michael@0: gEditor = null; michael@0: gSources = null; michael@0: });