From 76f18b83ab01540237ffef54023699679d7dd9e8 Mon Sep 17 00:00:00 2001 From: Fabian Stoehr Date: Thu, 28 Nov 2024 13:37:47 +0100 Subject: [PATCH] test: add test for fetching once in searchPanelControl --- .../src/components/SearchPanelControls.test.js | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/__tests__/src/components/SearchPanelControls.test.js b/__tests__/src/components/SearchPanelControls.test.js index 0b0189124..133d6dbf7 100644 --- a/__tests__/src/components/SearchPanelControls.test.js +++ b/__tests__/src/components/SearchPanelControls.test.js @@ -37,9 +37,23 @@ describe('SearchPanelControls', () => { await user.keyboard('somestring'); await user.click(await screen.findByText('somestring 12345')); expect(fetchSearch).toHaveBeenCalledWith('window', 'cw', 'http://example.com/search?q=somestring+12345', 'somestring 12345'); - fetch.resetMocks(); }); + it('should fetch result only once', async () => { + const fetchSearch = jest.fn(); + const user = userEvent.setup(); + + createWrapper({ + autocompleteService: { id: 'http://example.com/autocomplete' }, + fetchSearch, + searchService: { id: 'http://example.com/search', options: { resource: { id: 'abc' } } }, + }); + + await user.click(screen.getByRole('combobox')); + await user.keyboard('somestring'); + await user.keyboard('{Enter}'); + expect(fetchSearch).toHaveBeenCalledTimes(1); + }); it('renders a text input through the renderInput prop', () => { createWrapper();