-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathuseLoadSearchResults.test.ts
More file actions
70 lines (61 loc) · 1.76 KB
/
useLoadSearchResults.test.ts
File metadata and controls
70 lines (61 loc) · 1.76 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
import { act, renderHook } from '@testing-library/react';
import { useLoadSearchResults } from '@common/hooks/useLoadSearchResults';
import { useLoadingStateStore, useSearchStore } from '@src/store';
import { setInitialGlobalState, setUpdatedGlobalState } from '@src/test/__mocks__/store';
describe('useLoadSearchResults', () => {
const setData = jest.fn();
const fetchData = jest.fn();
const setSearchBy = jest.fn();
const setQuery = jest.fn();
const setIsLoading = jest.fn();
beforeEach(() => {
setInitialGlobalState([
{
store: useLoadingStateStore,
state: { isLoading: false, setIsLoading },
},
{
store: useSearchStore,
state: {
data: null,
searchBy: '',
query: '',
setQuery,
setData,
setSearchBy,
forceRefresh: false,
},
},
]);
});
it('updates state with query and searchBy', async () => {
Object.defineProperty(window, 'location', {
value: {
search: '?query=test%20query&searchBy=title',
},
writable: true,
});
act(() =>
setUpdatedGlobalState([
{
store: useSearchStore,
updatedState: { forceRefresh: false, searchBy: 'title' },
},
]),
);
renderHook(() => useLoadSearchResults(fetchData));
expect(setSearchBy).toHaveBeenCalledWith('title');
expect(setQuery).toHaveBeenCalledWith('test query');
});
it('clears data when no query param', () => {
Object.defineProperty(window, 'location', {
value: {
search: '',
},
writable: true,
});
renderHook(() => useLoadSearchResults(fetchData));
expect(setData).not.toHaveBeenCalled();
expect(fetchData).not.toHaveBeenCalled();
});
});