summaryrefslogtreecommitdiffstats
path: root/devtools/client/webconsole/test/browser_webconsole_autocomplete_accessibility.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/client/webconsole/test/browser_webconsole_autocomplete_accessibility.js')
-rw-r--r--devtools/client/webconsole/test/browser_webconsole_autocomplete_accessibility.js60
1 files changed, 60 insertions, 0 deletions
diff --git a/devtools/client/webconsole/test/browser_webconsole_autocomplete_accessibility.js b/devtools/client/webconsole/test/browser_webconsole_autocomplete_accessibility.js
new file mode 100644
index 000000000..bcd2e22d0
--- /dev/null
+++ b/devtools/client/webconsole/test/browser_webconsole_autocomplete_accessibility.js
@@ -0,0 +1,60 @@
+/* -*- 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");
+}