/* -*- 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 autocomplete input is being blurred and focused when selecting a value. // This will help screen-readers notify users of the value that was set in the input. "use strict"; const TEST_URI = "data:text/html;charset=utf8,<p>test code completion"; add_task(function* () { yield loadTab(TEST_URI); let hud = yield openConsole(); let jsterm = hud.jsterm; let input = jsterm.inputNode; info("Type 'd' to open the autocomplete popup"); yield autocomplete(jsterm, "d"); // Add listeners for focus and blur events. let wasBlurred = false; input.addEventListener("blur", () => { wasBlurred = true; }, { once: true }); let wasFocused = false; input.addEventListener("blur", () => { ok(wasBlurred, "jsterm input received a blur event before received back the focus"); wasFocused = true; }, { once: true }); info("Close the autocomplete popup by simulating a TAB key event"); let onPopupClosed = jsterm.autocompletePopup.once("popup-closed"); EventUtils.synthesizeKey("VK_TAB", {}); info("Wait for the autocomplete popup to be closed"); yield onPopupClosed; ok(wasFocused, "jsterm input received a focus event"); }); function* autocomplete(jsterm, value) { let popup = jsterm.autocompletePopup; yield new Promise(resolve => { jsterm.setInputValue(value); jsterm.complete(jsterm.COMPLETE_HINT_ONLY, resolve); }); ok(popup.isOpen && popup.itemCount > 0, "Autocomplete popup is open and contains suggestions"); }