mirror of
https://github.com/koel/koel
synced 2025-01-26 03:05:13 +00:00
55 lines
1.4 KiB
TypeScript
55 lines
1.4 KiB
TypeScript
import { expect, it } from 'vitest'
|
|
import factory from '@/__tests__/factory'
|
|
import { queueStore } from '@/stores'
|
|
import { playbackService } from '@/services'
|
|
import { screen } from '@testing-library/vue'
|
|
import UnitTestCase from '@/__tests__/UnitTestCase'
|
|
import SongListItem from './SongListItem.vue'
|
|
|
|
let row: SongRow
|
|
|
|
new class extends UnitTestCase {
|
|
private renderComponent (song?: Song) {
|
|
song = song ?? factory<Song>('song')
|
|
|
|
row = {
|
|
song,
|
|
selected: false
|
|
}
|
|
|
|
return this.render(SongListItem, {
|
|
props: {
|
|
item: row
|
|
}
|
|
})
|
|
}
|
|
|
|
protected test () {
|
|
it('renders', async () => {
|
|
const song = factory<Song>('song', {
|
|
title: 'Test Song',
|
|
album_name: 'Test Album',
|
|
artist_name: 'Test Artist',
|
|
length: 1000,
|
|
playback_state: 'Playing',
|
|
track: 12,
|
|
album_cover: 'https://example.com/cover.jpg',
|
|
liked: true
|
|
})
|
|
|
|
const { html } = await this.renderComponent(song)
|
|
expect(html()).toMatchSnapshot()
|
|
})
|
|
|
|
it('plays on double click', async () => {
|
|
const queueMock = this.mock(queueStore, 'queueIfNotQueued')
|
|
const playMock = this.mock(playbackService, 'play')
|
|
this.renderComponent()
|
|
|
|
await this.user.dblClick(screen.getByTestId('song-item'))
|
|
|
|
expect(queueMock).toHaveBeenCalledWith(row.song)
|
|
expect(playMock).toHaveBeenCalledWith(row.song)
|
|
})
|
|
}
|
|
}
|