mirror of
https://github.com/koel/koel
synced 2025-01-01 23:38:43 +00:00
45 lines
1.6 KiB
TypeScript
45 lines
1.6 KiB
TypeScript
|
import factory from '@/__tests__/factory'
|
||
|
import { mockHelper, render, stub } from '@/__tests__/__helpers__'
|
||
|
import { httpService } from '@/services'
|
||
|
import { eventBus } from '@/utils'
|
||
|
import { beforeEach, it } from 'vitest'
|
||
|
import { cleanup } from '@testing-library/vue'
|
||
|
import { EventName } from '@/config'
|
||
|
import ModalWrapper from './ModalWrapper.vue'
|
||
|
|
||
|
beforeEach(() => {
|
||
|
cleanup()
|
||
|
mockHelper.restoreAllMocks()
|
||
|
})
|
||
|
|
||
|
it.each<[string, EventName, User | Song | never]>([
|
||
|
['add-user-form', 'MODAL_SHOW_ADD_USER_FORM'],
|
||
|
['edit-user-form', 'MODAL_SHOW_EDIT_USER_FORM', factory('user')],
|
||
|
['edit-song-form', 'MODAL_SHOW_EDIT_SONG_FORM', [factory('song')]],
|
||
|
['create-smart-playlist-form', 'MODAL_SHOW_CREATE_SMART_PLAYLIST_FORM'],
|
||
|
['edit-smart-playlist-form', 'MODAL_SHOW_EDIT_SMART_PLAYLIST_FORM', factory('playlist')],
|
||
|
['about-koel', 'MODAL_SHOW_ABOUT_KOEL']
|
||
|
])('shows %s modal', async (modalName: string, eventName: EventName, eventParams?: any) => {
|
||
|
if (modalName === 'edit-song-form') {
|
||
|
// mocking the songInfoService.fetch() request made during edit-form modal opening
|
||
|
mockHelper.mock(httpService, 'request').mockReturnValue(Promise.resolve({ data: {} }))
|
||
|
}
|
||
|
|
||
|
const { findByTestId } = render(ModalWrapper, {
|
||
|
global: {
|
||
|
stubs: {
|
||
|
CreateSmartPlaylistForm: stub('create-smart-playlist-form'),
|
||
|
EditSmartPlaylistForm: stub('edit-smart-playlist-form'),
|
||
|
AddUserForm: stub('add-user-form'),
|
||
|
EditUserForm: stub('edit-user-form'),
|
||
|
EditSongForm: stub('edit-song-form'),
|
||
|
AboutKoel: stub('about-koel')
|
||
|
}
|
||
|
}
|
||
|
})
|
||
|
|
||
|
eventBus.emit(eventName, eventParams)
|
||
|
|
||
|
findByTestId(modalName)
|
||
|
})
|