Files
navidrome/ui/src/common/useResourceRefresh.test.js
T
Deluan Quintão fcdd30ba8f build(ui): migrate from CRA/Jest to Vite/Vitest (#3311)
* feat: create vite project

* feat: it's alive!

* feat: `make dev` working!

* feat: replace custom serviceWorker with vite plugin

* test: replace Jest with Vitest

* fix: run prettier

* fix: skip eslint for now.

* chore: remove ui.old folder

* refactor: replace lodash.pick with simple destructuring

* fix: eslint errors (wip)

* fix: eslint errors (wip)

* fix: display-name eslint errors (wip)

* fix: no-console eslint errors (wip)

* fix: react-refresh/only-export-components eslint errors (wip)

* fix: react-refresh/only-export-components eslint errors (wip)

* fix: react-refresh/only-export-components eslint errors (wip)

* fix: react-refresh/only-export-components eslint errors (wip)

* fix: build

* fix: pwa manifest

* refactor: pwa manifest

* refactor: simplify PORT configuration

* refactor: rename simple JS files

* test: cover playlistUtils

* fix: react-image-lightbox

* feat(ui): add sourcemaps to help debug issues
2024-09-28 11:54:36 -04:00

143 lines
4.2 KiB
JavaScript

import { vi } from 'vitest'
import * as React from 'react'
import * as Redux from 'react-redux'
import * as RA from 'react-admin'
import { useResourceRefresh } from './useResourceRefresh'
vi.mock('react', async () => {
const actual = await vi.importActual('react')
return {
...actual,
useState: vi.fn(),
}
})
vi.mock('react-redux', async () => {
const actual = await vi.importActual('react-redux')
return {
...actual,
useSelector: vi.fn(),
}
})
vi.mock('react-admin', async () => {
const actual = await vi.importActual('react-admin')
return {
...actual,
useRefresh: vi.fn(),
useDataProvider: vi.fn(),
}
})
describe('useResourceRefresh', () => {
const setState = vi.fn()
const useStateMock = (initState) => [initState, setState]
const refresh = vi.fn()
const useRefreshMock = () => refresh
const getMany = vi.fn()
const useDataProviderMock = () => ({ getMany })
let lastTime
beforeEach(() => {
vi.spyOn(React, 'useState').mockImplementation(useStateMock)
vi.spyOn(RA, 'useRefresh').mockImplementation(useRefreshMock)
vi.spyOn(RA, 'useDataProvider').mockImplementation(useDataProviderMock)
lastTime = new Date(new Date().valueOf() + 1000)
})
afterEach(() => {
vi.clearAllMocks()
})
it('stores last time checked, to avoid redundant runs', () => {
const useSelectorMock = () => ({ lastReceived: lastTime })
vi.spyOn(Redux, 'useSelector').mockImplementation(useSelectorMock)
useResourceRefresh()
expect(setState).toHaveBeenCalledWith(lastTime)
})
it("does not run again if lastTime didn't change", () => {
vi.spyOn(React, 'useState').mockImplementation(() => [lastTime, setState])
const useSelectorMock = () => ({ lastReceived: lastTime })
vi.spyOn(Redux, 'useSelector').mockImplementation(useSelectorMock)
useResourceRefresh()
expect(setState).not.toHaveBeenCalled()
})
describe('No visible resources specified', () => {
it('triggers a UI refresh when received a "any" resource refresh', () => {
const useSelectorMock = () => ({
lastReceived: lastTime,
resources: { '*': '*' },
})
vi.spyOn(Redux, 'useSelector').mockImplementation(useSelectorMock)
useResourceRefresh()
expect(refresh).toHaveBeenCalledTimes(1)
expect(getMany).not.toHaveBeenCalled()
})
it('triggers a UI refresh when received an "any" id', () => {
const useSelectorMock = () => ({
lastReceived: lastTime,
resources: { album: ['*'] },
})
vi.spyOn(Redux, 'useSelector').mockImplementation(useSelectorMock)
useResourceRefresh()
expect(refresh).toHaveBeenCalledTimes(1)
expect(getMany).not.toHaveBeenCalled()
})
it('triggers a refetch of the resources received', () => {
const useSelectorMock = () => ({
lastReceived: lastTime,
resources: { album: ['al-1', 'al-2'], song: ['sg-1', 'sg-2'] },
})
vi.spyOn(Redux, 'useSelector').mockImplementation(useSelectorMock)
useResourceRefresh()
expect(refresh).not.toHaveBeenCalled()
expect(getMany).toHaveBeenCalledTimes(2)
expect(getMany).toHaveBeenCalledWith('album', { ids: ['al-1', 'al-2'] })
expect(getMany).toHaveBeenCalledWith('song', { ids: ['sg-1', 'sg-2'] })
})
})
describe('Visible resources specified', () => {
it('triggers a UI refresh when received a "any" resource refresh', () => {
const useSelectorMock = () => ({
lastReceived: lastTime,
resources: { '*': '*' },
})
vi.spyOn(Redux, 'useSelector').mockImplementation(useSelectorMock)
useResourceRefresh('album')
expect(refresh).toHaveBeenCalledTimes(1)
expect(getMany).not.toHaveBeenCalled()
})
it('triggers a refetch of the resources received if they are visible', () => {
const useSelectorMock = () => ({
lastReceived: lastTime,
resources: { album: ['al-1', 'al-2'], song: ['sg-1', 'sg-2'] },
})
vi.spyOn(Redux, 'useSelector').mockImplementation(useSelectorMock)
useResourceRefresh('song')
expect(refresh).not.toHaveBeenCalled()
expect(getMany).toHaveBeenCalledTimes(1)
expect(getMany).toHaveBeenCalledWith('song', { ids: ['sg-1', 'sg-2'] })
})
})
})