From 90f2cd3b8c7cbab246ad9cc718777bc44bd8d6e9 Mon Sep 17 00:00:00 2001 From: Renato Atilio Date: Tue, 17 Dec 2024 14:27:57 -0300 Subject: [PATCH] DEV: add (broken) test --- .../tests/unit/lib/autocomplete-test.js | 31 +++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/app/assets/javascripts/discourse/tests/unit/lib/autocomplete-test.js b/app/assets/javascripts/discourse/tests/unit/lib/autocomplete-test.js index 92538da136f..70a954d3621 100644 --- a/app/assets/javascripts/discourse/tests/unit/lib/autocomplete-test.js +++ b/app/assets/javascripts/discourse/tests/unit/lib/autocomplete-test.js @@ -1,3 +1,4 @@ +import { triggerKeyEvent } from "@ember/test-helpers"; import { setupTest } from "ember-qunit"; import { compile } from "handlebars"; import $ from "jquery"; @@ -169,4 +170,34 @@ module("Unit | Utility | autocomplete", function (hooks) { assert.strictEqual(element.value, "@t"); }); + + test("Autocomplete does not trigger with right-left arrow keys", async function (assert) { + const element = textArea(); + + $(element).autocomplete({ + key: ":", + template, + transformComplete: (e) => e.slice(1), + dataSource: () => [":smile:"], + }); + + await simulateKeys(element, ":smi\t"); + + assert.dom(element).hasValue(":smile: "); + + ["ArrowLeft", "ArrowLeft", "ArrowLeft"].forEach((key) => + ["keydown", "keyup"].forEach(async (event) => { + await triggerKeyEvent(element, event, key, { code: key }); + }) + ); + + assert.strictEqual(element.selectionStart, 5); + + assert.dom("#ac-testing").doesNotExist(); + + await simulateKey(element, "\b"); + + assert.dom(element).hasValue(":smil"); + assert.dom("#ac-testing").exists(); + }); });