import { InfiniteData } from '@tanstack/react-query'; import { queryClient } from 'soapbox/queries/client'; import { PaginatedResult, sortQueryData, updatePageItem } from '../queries'; interface Item { id: number text: string } const buildItem = (id: number): Item => ({ id, text: `item ${id}` }); const queryKey = ['test', 'query']; describe('updatePageItem()', () => { beforeEach(() => { queryClient.clear(); }); describe('without cached data', () => { it('safely returns undefined', () => { updatePageItem(queryKey, buildItem(1), (o, n) => o.id === n.id); const nextQueryData = queryClient.getQueryData>>(queryKey); expect(nextQueryData).toBeUndefined(); }); }); describe('with cached data', () => { const cachedQueryData = { pages: [ { result: [buildItem(1), buildItem(2), buildItem(3)], hasMore: false, link: undefined, }, ], pageParams: [undefined], }; beforeEach(() => { queryClient.setQueryData(queryKey, cachedQueryData); }); it('updates the correct item in the cached data', () => { const initialQueryData = queryClient.getQueryData>>(queryKey); expect(initialQueryData?.pages[0].result.map((r) => r.id)).toEqual([1, 2, 3]); expect(initialQueryData?.pages[0].result.find((r) => r.id === 2)?.text).toEqual('item 2'); updatePageItem(queryKey, { id: 2, text: 'new text' }, (o, n) => o.id === n.id); const nextQueryData = queryClient.getQueryData>>(queryKey); expect(nextQueryData?.pages[0].result.map((r) => r.id)).toEqual([1, 2, 3]); expect(nextQueryData?.pages[0].result.find((r) => r.id === 2)?.text).toEqual('new text'); }); }); }); describe('sortQueryData()', () => { beforeEach(() => { queryClient.clear(); }); describe('without cached data', () => { it('safely returns undefined', () => { sortQueryData(queryKey, (a, b) => b.id - a.id); const nextQueryData = queryClient.getQueryData>>(queryKey); expect(nextQueryData).toBeUndefined(); }); }); describe('with cached data', () => { const cachedQueryData = { pages: [ { result: [...Array(20).fill(0).map((_, idx) => buildItem(idx))], hasMore: false, link: undefined, }, { result: [...Array(4).fill(0).map((_, idx) => buildItem(idx + 20))], hasMore: true, link: 'my-link', }, ], pageParams: [undefined], }; beforeEach(() => { queryClient.setQueryData(queryKey, cachedQueryData); }); it('sorts the cached data', () => { const initialQueryData = queryClient.getQueryData>>(queryKey); expect(initialQueryData?.pages[0].result[0].id === 0); // first id is 0 sortQueryData(queryKey, (a, b) => b.id - a.id); // sort descending const nextQueryData = queryClient.getQueryData>>(queryKey); expect(nextQueryData?.pages[0].result[0].id === 0); // first id is now 23 }); it('persists the metadata', () => { const initialQueryData = queryClient.getQueryData>>(queryKey); const initialMetaData = initialQueryData?.pages.map((page) => page.link); sortQueryData(queryKey, (a, b) => b.id - a.id); const nextQueryData = queryClient.getQueryData>>(queryKey); const nextMetaData = nextQueryData?.pages.map((page) => page.link); expect(initialMetaData).toEqual(nextMetaData); }); }); });