From 5f8de423f190bbb79a62f804151bc24824fa32d8 Mon Sep 17 00:00:00 2001 From: "Matt A. Tobin" Date: Fri, 2 Feb 2018 04:16:08 -0500 Subject: Add m-esr52 at 52.6.0 --- .../browser_dbg_breakpoints-new-script.js | 92 ++++++++++++++++++++++ 1 file changed, 92 insertions(+) create mode 100644 devtools/client/debugger/test/mochitest/browser_dbg_breakpoints-new-script.js (limited to 'devtools/client/debugger/test/mochitest/browser_dbg_breakpoints-new-script.js') diff --git a/devtools/client/debugger/test/mochitest/browser_dbg_breakpoints-new-script.js b/devtools/client/debugger/test/mochitest/browser_dbg_breakpoints-new-script.js new file mode 100644 index 000000000..6e0537f82 --- /dev/null +++ b/devtools/client/debugger/test/mochitest/browser_dbg_breakpoints-new-script.js @@ -0,0 +1,92 @@ +/* -*- 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/ */ + +/** + * Bug 771452: Make sure that setting a breakpoint in an inline source doesn't + * add it twice. + */ + +const TAB_URL = EXAMPLE_URL + "doc_inline-script.html"; + +function test() { + let options = { + source: TAB_URL, + line: 1 + }; + initDebugger(TAB_URL, options).then(([aTab,, aPanel]) => { + const gTab = aTab; + const gPanel = aPanel; + const gDebugger = gPanel.panelWin; + const gSources = gDebugger.DebuggerView.Sources; + const queries = gDebugger.require('./content/queries'); + const actions = bindActionCreators(gPanel); + const getState = gDebugger.DebuggerController.getState; + + function testResume() { + const deferred = promise.defer(); + is(gDebugger.gThreadClient.state, "paused", + "The breakpoint wasn't hit yet."); + + gDebugger.gThreadClient.resume(() => { + gDebugger.gThreadClient.addOneTimeListener("paused", (aEvent, aPacket) => { + waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FETCHED_SCOPES).then(() => { + is(aPacket.why.type, "breakpoint", + "Execution has advanced to the next breakpoint."); + isnot(aPacket.why.type, "debuggerStatement", + "The breakpoint was hit before the debugger statement."); + ok(isCaretPos(gPanel, 20), + "The source editor caret position is incorrect (2)."); + + deferred.resolve(); + }); + }); + + generateMouseClickInTab(gTab, "content.document.querySelector('button')"); + }); + + return deferred.promise; + } + + function testBreakpointHit() { + const deferred = promise.defer(); + is(gDebugger.gThreadClient.state, "paused", + "The breakpoint was hit."); + + gDebugger.gThreadClient.addOneTimeListener("paused", (aEvent, aPacket) => { + waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FETCHED_SCOPES).then(() => { + is(aPacket.why.type, "debuggerStatement", + "Execution has advanced to the next line."); + isnot(aPacket.why.type, "breakpoint", + "No ghost breakpoint was hit."); + ok(isCaretPos(gPanel, 20), + "The source editor caret position is incorrect (3)."); + + deferred.resolve(); + }); + }); + + EventUtils.sendMouseEvent({ type: "mousedown" }, + gDebugger.document.getElementById("resume"), + gDebugger); + return deferred.promise; + } + + Task.spawn(function(){ + let onCaretUpdated = waitForCaretAndScopes(gPanel, 16); + callInTab(gTab, "runDebuggerStatement"); + yield onCaretUpdated; + + is(gDebugger.gThreadClient.state, "paused", + "The debugger statement was reached."); + ok(isCaretPos(gPanel, 16), + "The source editor caret position is incorrect (1)."); + + yield actions.addBreakpoint({ actor: getSourceActor(gSources, TAB_URL), line: 20 }); + yield testResume(); + yield testBreakpointHit(); + resumeDebuggerThenCloseAndFinish(gPanel); + }); + }); +} -- cgit v1.2.3