2
0
Fork 0
mirror of https://github.com/koel/koel synced 2025-01-03 08:18:46 +00:00
koel/resources/assets/js/components/meta/SupportKoel.spec.ts

54 lines
1.6 KiB
TypeScript
Raw Normal View History

import { expect, it, vi } from 'vitest'
import { screen } from '@testing-library/vue'
import { preferenceStore } from '@/stores'
2022-05-13 17:58:38 +00:00
import UnitTestCase from '@/__tests__/UnitTestCase'
import SupportKoel from './SupportKoel.vue'
2022-05-13 17:58:38 +00:00
new class extends UnitTestCase {
protected beforeEach () {
super.beforeEach(() => vi.useFakeTimers())
}
protected afterEach () {
super.afterEach(() => {
vi.useRealTimers()
preferenceStore.state.supportBarNoBugging = false
})
}
private async renderComponent () {
preferenceStore.initialized.value = true
const rendered = this.render(SupportKoel)
vi.advanceTimersByTime(30 * 60 * 1000)
await this.tick()
return rendered
}
protected test () {
it('shows after a delay', async () => expect((await this.renderComponent()).html()).toMatchSnapshot())
it('does not show if user so demands', async () => {
preferenceStore.state.supportBarNoBugging = true
preferenceStore.initialized.value = true
expect((await this.renderComponent()).queryByTestId('support-bar')).toBeNull()
})
it('hides', async () => {
await this.renderComponent()
await this.user.click(screen.getByRole('button', { name: 'Hide' }))
expect(screen.queryByTestId('support-bar')).toBeNull()
})
it('hides and does not bug again', async () => {
await this.renderComponent()
await this.user.click(screen.getByRole('button', { name: 'Don\'t bug me again' }))
expect(await screen.queryByTestId('support-bar')).toBeNull()
expect(preferenceStore.state.supportBarNoBugging).toBe(true)
})
}
}