koel/resources/assets/js/components/screens/FavoritesScreen.spec.ts

38 lines
1.1 KiB
TypeScript
Raw Normal View History

import { screen, waitFor } from '@testing-library/vue'
2022-07-12 08:37:11 +00:00
import { expect, it } from 'vitest'
import factory from '@/__tests__/factory'
import UnitTestCase from '@/__tests__/UnitTestCase'
import { favoriteStore } from '@/stores'
import FavoritesScreen from './FavoritesScreen.vue'
new class extends UnitTestCase {
private async renderComponent () {
const fetchMock = this.mock(favoriteStore, 'fetch')
this.render(FavoritesScreen)
await this.router.activateRoute({ path: 'favorites', screen: 'Favorites' })
2022-07-12 08:37:11 +00:00
await waitFor(() => expect(fetchMock).toHaveBeenCalled())
}
protected test () {
it('renders a list of favorites', async () => {
favoriteStore.state.songs = factory<Song>('song', 13)
await this.renderComponent()
2022-07-12 08:37:11 +00:00
await waitFor(() => {
expect(screen.queryByTestId('screen-empty-state')).toBeNull()
screen.getByTestId('song-list')
2022-07-12 08:37:11 +00:00
})
})
it('shows empty state', async () => {
favoriteStore.state.songs = []
await this.renderComponent()
2022-07-12 08:37:11 +00:00
screen.getByTestId('screen-empty-state')
expect(screen.queryByTestId('song-list')).toBeNull()
2022-07-12 08:37:11 +00:00
})
}
}