From bfd1274d2931430f1d929e10d5d57f0b5accf028 Mon Sep 17 00:00:00 2001 From: Yannick Croissant Date: Wed, 27 Jan 2021 15:49:25 +0100 Subject: [PATCH] fix(core): remove error handler when fetching results --- .../src/__tests__/getInputProps.test.ts | 25 ++++++++++++++++++- packages/autocomplete-core/src/onInput.ts | 5 ---- 2 files changed, 24 insertions(+), 6 deletions(-) diff --git a/packages/autocomplete-core/src/__tests__/getInputProps.test.ts b/packages/autocomplete-core/src/__tests__/getInputProps.test.ts index 2eeb0a021..91775b981 100644 --- a/packages/autocomplete-core/src/__tests__/getInputProps.test.ts +++ b/packages/autocomplete-core/src/__tests__/getInputProps.test.ts @@ -553,7 +553,30 @@ describe('getInputProps', () => { }); }); - test.todo('catches errors and sets status to error'); + /* eslint-disable-next-line jest/no-done-callback */ + test('lets user handle the errors', (done) => { + const getSources = jest.fn((..._args: any[]) => { + return [ + createSource({ + getItems() { + return new Promise((resolve, reject) => { + reject(new Error('Fetch error')); + }).catch((err) => { + expect(err).toEqual(expect.any(Error)); + done(); + return []; + }); + }, + }), + ]; + }); + + const { inputElement } = createPlayground(createAutocomplete, { + getSources, + }); + + userEvent.type(inputElement, 'a'); + }); test('clears stalled timeout', async () => { const environment = { diff --git a/packages/autocomplete-core/src/onInput.ts b/packages/autocomplete-core/src/onInput.ts index d53339177..db4194beb 100644 --- a/packages/autocomplete-core/src/onInput.ts +++ b/packages/autocomplete-core/src/onInput.ts @@ -141,11 +141,6 @@ export function onInput({ }); } }) - .catch((error) => { - setStatus('error'); - - throw error; - }) .finally(() => { if (lastStalledId) { props.environment.clearTimeout(lastStalledId);