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_variables-view-popup-12.js | 77 ++++++++++++++++++++++ 1 file changed, 77 insertions(+) create mode 100644 devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-12.js (limited to 'devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-12.js') diff --git a/devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-12.js b/devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-12.js new file mode 100644 index 000000000..588276434 --- /dev/null +++ b/devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-12.js @@ -0,0 +1,77 @@ +/* -*- 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 that the clicking "Watch" button twice, for the same expression, only adds it + * once. + */ + +const TAB_URL = EXAMPLE_URL + "doc_watch-expression-button.html"; + +function test() { + Task.spawn(function* () { + let options = { + source: TAB_URL, + line: 1 + }; + let [tab,, panel] = yield initDebugger(TAB_URL, options); + let win = panel.panelWin; + let events = win.EVENTS; + let watch = win.DebuggerView.WatchExpressions; + let bubble = win.DebuggerView.VariableBubble; + let tooltip = bubble._tooltip.panel; + + function verifyContent(aExpression, aItemCount) { + + ok(watch.getItemAtIndex(0), + "The expression at index 0 should be available."); + is(watch.getItemAtIndex(0).attachment.initialExpression, aExpression, + "The expression at index 0 is correct."); + is(watch.itemCount, aItemCount, + "The expression count is correct."); + } + + let onCaretAndScopes = waitForCaretAndScopes(panel, 19); + callInTab(tab, "start"); + yield onCaretAndScopes; + + // Inspect primitive value variable. + yield openVarPopup(panel, { line: 15, ch: 12 }); + let popupHiding = once(tooltip, "popuphiding"); + let expressionsEvaluated = waitForDebuggerEvents(panel, events.FETCHED_WATCH_EXPRESSIONS); + tooltip.querySelector("button").click(); + verifyContent("a", 1); + yield promise.all([popupHiding, expressionsEvaluated]); + ok(true, "The new watch expressions were re-evaluated and the panel got hidden (1)."); + + // Inspect property of an object. + expressionsEvaluated = waitForDebuggerEvents(panel, events.FETCHED_WATCH_EXPRESSIONS); + yield openVarPopup(panel, { line: 17, ch: 10 }); + yield expressionsEvaluated; + ok(true, "The watch expressions were re-evaluated when a new panel opened (1)."); + + popupHiding = once(tooltip, "popuphiding"); + expressionsEvaluated = waitForDebuggerEvents(panel, events.FETCHED_WATCH_EXPRESSIONS); + tooltip.querySelector("button").click(); + verifyContent("b.a", 2); + yield promise.all([popupHiding, expressionsEvaluated]); + ok(true, "The new watch expressions were re-evaluated and the panel got hidden (2)."); + + // Re-inspect primitive value variable. + expressionsEvaluated = waitForDebuggerEvents(panel, events.FETCHED_WATCH_EXPRESSIONS); + yield openVarPopup(panel, { line: 15, ch: 12 }); + yield expressionsEvaluated; + ok(true, "The watch expressions were re-evaluated when a new panel opened (2)."); + + popupHiding = once(tooltip, "popuphiding"); + expressionsEvaluated = waitForDebuggerEvents(panel, events.FETCHED_WATCH_EXPRESSIONS); + tooltip.querySelector("button").click(); + verifyContent("b.a", 2); + yield promise.all([popupHiding, expressionsEvaluated]); + ok(true, "The new watch expressions were re-evaluated and the panel got hidden (3)."); + + yield resumeDebuggerThenCloseAndFinish(panel); + }); +} -- cgit v1.2.3