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_controller-evaluate-02.js | 78 ++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 devtools/client/debugger/test/mochitest/browser_dbg_controller-evaluate-02.js (limited to 'devtools/client/debugger/test/mochitest/browser_dbg_controller-evaluate-02.js') diff --git a/devtools/client/debugger/test/mochitest/browser_dbg_controller-evaluate-02.js b/devtools/client/debugger/test/mochitest/browser_dbg_controller-evaluate-02.js new file mode 100644 index 000000000..ff4092e1d --- /dev/null +++ b/devtools/client/debugger/test/mochitest/browser_dbg_controller-evaluate-02.js @@ -0,0 +1,78 @@ +/* -*- 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 the public evaluation API from the debugger controller. + */ + +const TAB_URL = EXAMPLE_URL + "doc_script-switching-01.html"; + +function test() { + Task.spawn(function* () { + const options = { + source: EXAMPLE_URL + "code_script-switching-01.js", + line: 1 + }; + const [tab,, panel] = yield initDebugger(TAB_URL, options); + const win = panel.panelWin; + const frames = win.DebuggerController.StackFrames; + const framesView = win.DebuggerView.StackFrames; + const sourcesView = win.DebuggerView.Sources; + const editorView = win.DebuggerView.editor; + const events = win.EVENTS; + const queries = win.require("./content/queries"); + const constants = win.require("./content/constants"); + const actions = bindActionCreators(panel); + const getState = win.DebuggerController.getState; + + function checkView(selectedFrame, selectedSource, caretLine, editorText) { + is(win.gThreadClient.state, "paused", + "Should only be getting stack frames while paused."); + is(framesView.itemCount, 2, + "Should have four frames."); + is(framesView.selectedDepth, selectedFrame, + "The correct frame is selected in the widget."); + is(sourcesView.selectedIndex, selectedSource, + "The correct source is selected in the widget."); + ok(isCaretPos(panel, caretLine), + "Editor caret location is correct."); + is(editorView.getText().search(editorText[0]), editorText[1], + "The correct source is not displayed."); + } + + // Cache the sources text to avoid having to wait for their + // retrieval. + const sources = queries.getSources(getState()); + yield promise.all(Object.keys(sources).map(k => { + return actions.loadSourceText(sources[k]); + })); + + // Allow this generator function to yield first. + callInTab(tab, "firstCall"); + yield waitForSourceAndCaretAndScopes(panel, "-02.js", 6); + checkView(0, 1, 6, [/secondCall/, 118]); + + // Change the selected frame and eval inside it. + let updatedFrame = waitForDebuggerEvents(panel, events.FETCHED_SCOPES); + framesView.selectedDepth = 1; // oldest frame + yield updatedFrame; + checkView(1, 0, 5, [/firstCall/, 118]); + + let updatedView = waitForDebuggerEvents(panel, events.FETCHED_SCOPES); + try { + yield frames.evaluate("foo"); + } catch (result) { + is(result.return.type, "object", "The evaluation thrown type is correct."); + is(result.return.class, "Error", "The evaluation thrown class is correct."); + ok(!result.return, "The evaluation hasn't returned."); + } + + yield updatedView; + checkView(1, 0, 5, [/firstCall/, 118]); + ok(true, "Evaluating while in a user-selected frame works properly."); + + yield resumeDebuggerThenCloseAndFinish(panel); + }); +} -- cgit v1.2.3