mirror of
https://github.com/koel/koel
synced 2025-01-04 08:48:48 +00:00
131 lines
4.8 KiB
TypeScript
131 lines
4.8 KiB
TypeScript
import factory from '@/__tests__/factory'
|
|
import { reactive } from 'vue'
|
|
import UnitTestCase from '@/__tests__/UnitTestCase'
|
|
import { expect, it } from 'vitest'
|
|
import { http } from '@/services'
|
|
import { queueStore, songStore } from '.'
|
|
|
|
let playables: Playable[]
|
|
|
|
new class extends UnitTestCase {
|
|
protected beforeEach () {
|
|
super.beforeEach(() => {
|
|
playables = factory('song', 3)
|
|
queueStore.state.playables = reactive(playables)
|
|
})
|
|
}
|
|
|
|
protected test () {
|
|
it('returns all queued songs', () => expect(queueStore.all).toEqual(playables))
|
|
|
|
it('returns the first queued song', () => expect(queueStore.first).toEqual(playables[0]))
|
|
|
|
it('returns the last queued song', () => expect(queueStore.last).toEqual(playables[2]))
|
|
|
|
it('queues to bottom', () => {
|
|
const song = factory('song')
|
|
const putMock = this.mock(http, 'put')
|
|
queueStore.queue(song)
|
|
|
|
expect(queueStore.all).toHaveLength(4)
|
|
expect(queueStore.last).toEqual(song)
|
|
expect(putMock).toHaveBeenCalledWith('queue/state', { songs: queueStore.all.map(song => song.id) })
|
|
})
|
|
|
|
it('queues to top', () => {
|
|
const song = factory('song')
|
|
const putMock = this.mock(http, 'put')
|
|
queueStore.queueToTop(song)
|
|
|
|
expect(queueStore.all).toHaveLength(4)
|
|
expect(queueStore.first).toEqual(song)
|
|
expect(putMock).toHaveBeenCalledWith('queue/state', { songs: queueStore.all.map(song => song.id) })
|
|
})
|
|
|
|
it('replaces the whole queue', () => {
|
|
const newSongs = factory('song', 2)
|
|
const putMock = this.mock(http, 'put')
|
|
queueStore.replaceQueueWith(newSongs)
|
|
|
|
expect(queueStore.all).toEqual(newSongs)
|
|
expect(putMock).toHaveBeenCalledWith('queue/state', { songs: newSongs.map(song => song.id) })
|
|
})
|
|
|
|
it('removes a song from queue', () => {
|
|
const putMock = this.mock(http, 'put')
|
|
queueStore.unqueue(playables[1])
|
|
|
|
expect(queueStore.all).toEqual([playables[0], playables[2]])
|
|
expect(putMock).toHaveBeenCalledWith('queue/state', { songs: queueStore.all.map(song => song.id) })
|
|
})
|
|
|
|
it('removes multiple songs from queue', () => {
|
|
const putMock = this.mock(http, 'put')
|
|
queueStore.unqueue([playables[1], playables[0]])
|
|
|
|
expect(queueStore.all).toEqual([playables[2]])
|
|
expect(putMock).toHaveBeenCalledWith('queue/state', { songs: queueStore.all.map(song => song.id) })
|
|
})
|
|
|
|
it('clears the queue', () => {
|
|
const putMock = this.mock(http, 'put')
|
|
queueStore.clear()
|
|
|
|
expect(queueStore.state.playables).toHaveLength(0)
|
|
expect(putMock).toHaveBeenCalledWith('queue/state', { songs: [] })
|
|
})
|
|
|
|
it.each<[PlaybackState]>([['Playing'], ['Paused']])('identifies the current song by %s state', state => {
|
|
queueStore.state.playables[1].playback_state = state
|
|
expect(queueStore.current).toEqual(queueStore.state.playables[1])
|
|
})
|
|
|
|
it('gets the next song in queue', () => {
|
|
queueStore.state.playables[1].playback_state = 'Playing'
|
|
expect(queueStore.next).toEqual(queueStore.state.playables[2])
|
|
})
|
|
|
|
it('returns undefined as next song if at end of queue', () => {
|
|
queueStore.state.playables[2].playback_state = 'Playing'
|
|
expect(queueStore.next).toBeUndefined()
|
|
})
|
|
|
|
it('gets the previous song in queue', () => {
|
|
queueStore.state.playables[1].playback_state = 'Playing'
|
|
expect(queueStore.previous).toEqual(queueStore.state.playables[0])
|
|
})
|
|
|
|
it('returns undefined as previous song if at beginning of queue', () => {
|
|
queueStore.state.playables[0].playback_state = 'Playing'
|
|
expect(queueStore.previous).toBeUndefined()
|
|
})
|
|
|
|
it('fetches random songs to queue', async () => {
|
|
const songs = factory('song', 3)
|
|
const getMock = this.mock(http, 'get').mockResolvedValue(songs)
|
|
const syncMock = this.mock(songStore, 'syncWithVault', songs)
|
|
const putMock = this.mock(http, 'put')
|
|
|
|
await queueStore.fetchRandom(3)
|
|
|
|
expect(getMock).toHaveBeenCalledWith('queue/fetch?order=rand&limit=3')
|
|
expect(syncMock).toHaveBeenCalledWith(songs)
|
|
expect(queueStore.all).toEqual(songs)
|
|
expect(putMock).toHaveBeenCalledWith('queue/state', { songs: songs.map(song => song.id) })
|
|
})
|
|
|
|
it('fetches random songs to queue with a custom order', async () => {
|
|
const songs = factory('song', 3)
|
|
const getMock = this.mock(http, 'get').mockResolvedValue(songs)
|
|
const syncMock = this.mock(songStore, 'syncWithVault', songs)
|
|
const putMock = this.mock(http, 'put')
|
|
|
|
await queueStore.fetchInOrder('title', 'desc', 3)
|
|
|
|
expect(getMock).toHaveBeenCalledWith('queue/fetch?order=desc&sort=title&limit=3')
|
|
expect(syncMock).toHaveBeenCalledWith(songs)
|
|
expect(queueStore.all).toEqual(songs)
|
|
expect(putMock).toHaveBeenCalledWith('queue/state', { songs: songs.map(song => song.id) })
|
|
})
|
|
}
|
|
}
|