/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at . */ // Tests that after clicking a function in edtior, outline focuses that function "use strict"; // Tests that after clicking a function in edtior, outline focuses that function add_task(async function () { const dbg = await initDebugger("doc-sources.html", "long.js"); await selectSource(dbg, "long.js", 1); await openOutlinePanel(dbg); is( findAllElements(dbg, "outlineItems").length, 9, "9 items in the outline list" ); info("Clicking inside a function in editor should focus the outline"); await clickAtPos(dbg, { line: 15, column: 3 }); await waitForElementWithSelector(dbg, ".outline-list__element.focused"); ok( getFocusedFunction(dbg).includes("addTodo"), "The right function is focused" ); info("Clicking an empty line in the editor should unfocus the outline"); await clickAtPos(dbg, { line: 12, column: 3 }); // Wait for the node to be unfocused await waitFor(() => !getFocusedNode(dbg)); is(getFocusedNode(dbg), null, "should not exist"); }); // Tests that clicking a function in outline panel, the editor highlights the correct location. add_task(async function () { const dbg = await initDebugger("doc-scripts.html", "simple1.js"); await selectSource(dbg, "simple1.js", 1); await openOutlinePanel(dbg); assertOutlineItems(dbg, [ "λmain()", "λdoEval()", "λevaledFunc()", "λdoNamedEval()", // evaledFunc is set twice "λevaledFunc()", "λnormalFunction(foo)", "λletFunction(a)", "λconstFunction(x)", "λProtoClass(a)", "λprotoFoo(foo)", "λprotoBar(x, y)", "λprotoBoo(x)", "λ1234()", "λmemFoo(a, b)", "λarrFoo(c)", "class MyClass", "λconstructor(a, b)", "λtest()", "λ#privateFunc(a, b)", "class Klass", "λconstructor()", "λtest()", "λbar()", "λboo(a)", ]); info("Click an item in outline panel"); const item = getNthItem(dbg, 3); item.click(); await waitForLoadedSource(dbg, "simple1.js"); assertHighlightLocation(dbg, "simple1.js", 15); ok( item.parentNode.classList.contains("focused"), "The clicked item li is focused" ); }); // Clicking on a class heading select the correct class line function getFocusedNode(dbg) { return findElementWithSelector(dbg, ".outline-list__element.focused"); } function getFocusedFunction(dbg) { return getFocusedNode(dbg).innerText; } function getNthItem(dbg, index) { return findElement(dbg, "outlineItem", index); }