diff options
Diffstat (limited to 'devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-07.js')
-rw-r--r-- | devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-07.js | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-07.js b/devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-07.js new file mode 100644 index 000000000..1340f14c6 --- /dev/null +++ b/devtools/client/debugger/test/mochitest/browser_dbg_variables-view-popup-07.js @@ -0,0 +1,70 @@ +/* -*- 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 variable inspection popup behaves correctly when switching + * between simple and complex objects. + */ + +const TAB_URL = EXAMPLE_URL + "doc_frame-parameters.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 bubble = win.DebuggerView.VariableBubble; + let tooltip = bubble._tooltip.panel; + + function verifySimpleContents(textContent, className) { + is(tooltip.querySelectorAll(".variables-view-container").length, 0, + "There should be no variables view container added to the tooltip."); + is(tooltip.querySelectorAll(".devtools-tooltip-simple-text").length, 1, + "There should be one simple text node added to the tooltip."); + + is(tooltip.querySelector(".devtools-tooltip-simple-text").textContent, textContent, + "The inspected property's value is correct."); + ok(tooltip.querySelector(".devtools-tooltip-simple-text").className.includes(className), + "The inspected property's value is colorized correctly."); + } + + function verifyComplexContents(propertyCount) { + is(tooltip.querySelectorAll(".variables-view-container").length, 1, + "There should be one variables view container added to the tooltip."); + is(tooltip.querySelectorAll(".devtools-tooltip-simple-text").length, 0, + "There should be no simple text node added to the tooltip."); + + is(tooltip.querySelectorAll(".variables-view-scope[untitled]").length, 1, + "There should be one scope with no header displayed."); + is(tooltip.querySelectorAll(".variables-view-variable[untitled]").length, 1, + "There should be one variable with no header displayed."); + + ok(tooltip.querySelectorAll(".variables-view-property").length >= propertyCount, + "There should be some properties displayed."); + } + + let onCaretAndScopes = waitForCaretAndScopes(panel, 24); + callInTab(tab, "start"); + yield onCaretAndScopes; + + // Inspect variables. + yield openVarPopup(panel, { line: 15, ch: 12 }); + verifySimpleContents("1", "token-number"); + + yield reopenVarPopup(panel, { line: 16, ch: 12 }, true); + verifyComplexContents(2); + + yield reopenVarPopup(panel, { line: 19, ch: 10 }); + verifySimpleContents("42", "token-number"); + + yield reopenVarPopup(panel, { line: 31, ch: 10 }, true); + verifyComplexContents(100); + + yield resumeDebuggerThenCloseAndFinish(panel); + }); +} |