From 6bd4b05a98ef7e3a710bac58194218f129125407 Mon Sep 17 00:00:00 2001 From: Nolan Lawson Date: Sat, 21 Apr 2018 14:57:02 -0700 Subject: [PATCH] fix more bugs in autocomplete (#208) * fix more bugs in autocomplete fully fixes #170 * fixup * fix tests --- .../compose/ComposeAutosuggest.html | 12 ++++- tests/roles.js | 4 +- tests/spec/002-login-spec.js | 2 +- tests/spec/018-compose-autosuggest.js | 44 ++++++++++++++----- 4 files changed, 45 insertions(+), 17 deletions(-) diff --git a/routes/_components/compose/ComposeAutosuggest.html b/routes/_components/compose/ComposeAutosuggest.html index 6d42a909..89186408 100644 --- a/routes/_components/compose/ComposeAutosuggest.html +++ b/routes/_components/compose/ComposeAutosuggest.html @@ -83,7 +83,8 @@ } }) this.observe('searchText', async searchText => { - if (!searchText) { + let { thisComposeFocused } = this.get() + if (!thisComposeFocused || !searchText) { return } let type = searchText.startsWith('@') ? 'account' : 'emoji' @@ -98,6 +99,10 @@ }) }) this.observe('shown', shown => { + let { thisComposeFocused } = this.get() + if (!thisComposeFocused) { + return + } this.store.set({composeAutosuggestionShown: shown}) }) }, @@ -138,7 +143,10 @@ searchResults: ($composeAutosuggestionSearchResults) => $composeAutosuggestionSearchResults || [], type: ($composeAutosuggestionType) => $composeAutosuggestionType || 'account', selected: ($composeAutosuggestionSelected) => $composeAutosuggestionSelected || 0, - searchText: (text, composeSelectionStartDeferred) => { + searchText: (text, composeSelectionStartDeferred, thisComposeFocused) => { + if (!thisComposeFocused) { + return + } let selectionStart = composeSelectionStartDeferred || 0 if (!text || selectionStart < MIN_PREFIX_LENGTH) { return diff --git a/tests/roles.js b/tests/roles.js index 7673af78..cb693eb6 100644 --- a/tests/roles.js +++ b/tests/roles.js @@ -8,13 +8,13 @@ import { function login (t, username, password) { return t.typeText(instanceInput, 'localhost:3000', {paste: true}) .click(addInstanceButton) - .expect(getUrl()).eql('http://localhost:3000/auth/sign_in') + .expect(getUrl()).eql('http://localhost:3000/auth/sign_in', {timeout: 30000}) .typeText(emailInput, username, {paste: true}) .typeText(passwordInput, password, {paste: true}) .click(mastodonLogInButton) .expect(getUrl()).contains('/oauth/authorize') .click(authorizeInput) - .expect(getUrl()).eql('http://localhost:4002/', {timeout: 20000}) + .expect(getUrl()).eql('http://localhost:4002/', {timeout: 30000}) } export const foobarRole = Role('http://localhost:4002/settings/instances/add', async t => { diff --git a/tests/spec/002-login-spec.js b/tests/spec/002-login-spec.js index a660611a..ab421aa8 100644 --- a/tests/spec/002-login-spec.js +++ b/tests/spec/002-login-spec.js @@ -15,7 +15,7 @@ function manualLogin (t, username, password) { .expect(getUrl()).contains('/settings/instances/add') .typeText(instanceInput, 'localhost:3000') .click(addInstanceButton) - .expect(getUrl()).eql('http://localhost:3000/auth/sign_in') + .expect(getUrl()).eql('http://localhost:3000/auth/sign_in', {timeout: 30000}) .typeText(emailInput, username, {paste: true}) .typeText(passwordInput, password, {paste: true}) .click(mastodonLogInButton) diff --git a/tests/spec/018-compose-autosuggest.js b/tests/spec/018-compose-autosuggest.js index a4d309a4..f1c3df2d 100644 --- a/tests/spec/018-compose-autosuggest.js +++ b/tests/spec/018-compose-autosuggest.js @@ -1,5 +1,5 @@ import { - composeInput, getNthAutosuggestionResult, getNthComposeReplyInput, getNthReplyButton, getNthStatus + composeInput, getNthAutosuggestionResult, getNthComposeReplyInput, getNthReplyButton, getNthStatus, sleep } from '../utils' import { Selector as $ } from 'testcafe' import { foobarRole } from '../roles' @@ -7,21 +7,25 @@ import { foobarRole } from '../roles' fixture`018-compose-autosuggest.js` .page`http://localhost:4002` +const timeout = 30000 + test('autosuggests user handles', async t => { await t.useRole(foobarRole) .hover(composeInput) + await sleep(1000) + await t .typeText(composeInput, 'hey @qu') - .click(getNthAutosuggestionResult(1)) + .click(getNthAutosuggestionResult(1), {timeout}) .expect(composeInput.value).eql('hey @quux ') .typeText(composeInput, 'and also @adm') - .click(getNthAutosuggestionResult(1)) + .click(getNthAutosuggestionResult(1), {timeout}) .expect(composeInput.value).eql('hey @quux and also @admin ') .typeText(composeInput, 'and also @AdM') - .expect(getNthAutosuggestionResult(1).innerText).contains('@admin') + .expect(getNthAutosuggestionResult(1).innerText).contains('@admin', {timeout}) .pressKey('tab') .expect(composeInput.value).eql('hey @quux and also @admin and also @admin ') .typeText(composeInput, 'and @QU') - .expect(getNthAutosuggestionResult(1).innerText).contains('@quux') + .expect(getNthAutosuggestionResult(1).innerText).contains('@quux', {timeout}) .pressKey('enter') .expect(composeInput.value).eql('hey @quux and also @admin and also @admin and @quux ') }) @@ -33,15 +37,15 @@ test('autosuggests custom emoji', async t => { .click(getNthAutosuggestionResult(1)) .expect(composeInput.value).eql(':blobnom: ') .typeText(composeInput, 'and :blob') - .expect(getNthAutosuggestionResult(1).innerText).contains(':blobnom:') + .expect(getNthAutosuggestionResult(1).innerText).contains(':blobnom:', {timeout}) .expect(getNthAutosuggestionResult(2).innerText).contains(':blobpats:') .expect(getNthAutosuggestionResult(3).innerText).contains(':blobpeek:') .pressKey('down') .pressKey('down') .pressKey('enter') - .expect(composeInput.value).eql(':blobnom: and :blobpeek: ') + .expect(composeInput.value).eql(':blobnom: and :blobpeek: ', {timeout}) .typeText(composeInput, 'and also :blobpa') - .expect(getNthAutosuggestionResult(1).innerText).contains(':blobpats:') + .expect(getNthAutosuggestionResult(1).innerText).contains(':blobpats:', {timeout}) .pressKey('tab') .expect(composeInput.value).eql(':blobnom: and :blobpeek: and also :blobpats: ') }) @@ -50,7 +54,7 @@ test('autosuggest custom emoji works with regular emoji - keyboard', async t => await t.useRole(foobarRole) .hover(composeInput) .typeText(composeInput, '\ud83c\udf4d :blobno') - .expect(getNthAutosuggestionResult(1).innerText).contains(':blobnom:') + .expect(getNthAutosuggestionResult(1).innerText).contains(':blobnom:', {timeout}) .pressKey('enter') .expect(composeInput.value).eql('\ud83c\udf4d :blobnom: ') }) @@ -59,7 +63,7 @@ test('autosuggest custom emoji works with regular emoji - clicking', async t => await t.useRole(foobarRole) .hover(composeInput) .typeText(composeInput, '\ud83c\udf4d :blobno') - .expect(getNthAutosuggestionResult(1).innerText).contains(':blobnom:') + .expect(getNthAutosuggestionResult(1).innerText).contains(':blobnom:', {timeout}) .click(getNthAutosuggestionResult(1)) .expect(composeInput.value).eql('\ud83c\udf4d :blobnom: ') }) @@ -68,7 +72,7 @@ test('autosuggest handles works with regular emoji - keyboard', async t => { await t.useRole(foobarRole) .hover(composeInput) .typeText(composeInput, '\ud83c\udf4d @quu') - .expect(getNthAutosuggestionResult(1).innerText).contains('@quux') + .expect(getNthAutosuggestionResult(1).innerText).contains('@quux', {timeout}) .pressKey('enter') .expect(composeInput.value).eql('\ud83c\udf4d @quux ') }) @@ -77,7 +81,7 @@ test('autosuggest handles works with regular emoji - clicking', async t => { await t.useRole(foobarRole) .hover(composeInput) .typeText(composeInput, '\ud83c\udf4d @quu') - .expect(getNthAutosuggestionResult(1).innerText).contains('@quux') + .expect(getNthAutosuggestionResult(1).innerText).contains('@quux', {timeout}) .click(getNthAutosuggestionResult(1)) .expect(composeInput.value).eql('\ud83c\udf4d @quux ') }) @@ -93,3 +97,19 @@ test('autosuggest only shows for one input', async t => { .typeText(getNthComposeReplyInput(0), 'uu') .expect($('.compose-autosuggest.shown').exists).notOk() }) + +test('autosuggest only shows for one input part 2', async t => { + await t.useRole(foobarRole) + .hover(composeInput) + .typeText(composeInput, '@adm') + .expect($('.compose-autosuggest.shown').exists).ok({timeout}) + .expect(getNthAutosuggestionResult(1).innerText).contains('@admin') + .hover(getNthStatus(0)) + .click(getNthReplyButton(0)) + .selectText(getNthComposeReplyInput(0)) + .pressKey('delete') + .typeText(getNthComposeReplyInput(0), '@dd') + await sleep(1000) + await t.pressKey('backspace') + .expect($('.compose-autosuggest.shown').exists).notOk() +})