vitest/examples/lit/test/basic.test.ts
Anthony Fu d4415fe112
fix: describe async support (#750)
* Revert "fix: remove `describe` async support (#746)"

This reverts commit f9b52c1be16329a0ca5ae5d67a4b3141b4389714.

* fix: collect nested suite serially
2022-02-14 14:48:48 +08:00

41 lines
1.1 KiB
TypeScript

import type { IWindow } from 'happy-dom'
import { beforeEach, describe, it, vi } from 'vitest'
import '../src/my-button'
declare global {
interface Window extends IWindow {}
}
describe('Button with increment', async() => {
beforeEach(async() => {
document.body.innerHTML = '<my-button name="World"></my-button>'
await window.happyDOM.whenAsyncComplete()
await new Promise(resolve => setTimeout(resolve, 0))
})
function getInsideButton(): HTMLElement | null | undefined {
return document.body.querySelector('my-button')?.shadowRoot?.querySelector('button')
}
it('should increment the count on each click', () => {
getInsideButton()?.click()
expect(getInsideButton()?.innerText).toContain('1')
})
it('should show name props', () => {
getInsideButton()
expect(document.body.querySelector('my-button')?.shadowRoot?.innerHTML).toContain('World')
})
it('should dispatch count event on button click', () => {
const spyClick = vi.fn()
document.querySelector('my-button')!.addEventListener('count', spyClick)
getInsideButton()?.click()
expect(spyClick).toHaveBeenCalled()
})
})