vitest/examples/lit/test/basic.test.ts
renovate[bot] 84a066af0e
chore(deps): update dependency @antfu/eslint-config to v3 (#6435)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Vladimir Sheremet <sleuths.slews0s@icloud.com>
2024-09-02 10:16:37 +02:00

34 lines
950 B
TypeScript

import { beforeEach, describe, expect, it, vi } from 'vitest'
import '../src/my-button.js'
describe('Button with increment', async () => {
beforeEach(() => {
document.body.innerHTML = '<my-button name="World"></my-button>'
})
it('should increment the count on each click', () => {
getInsideButton()?.click()
expect(getInsideButton()?.textContent).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()
})
})
function getInsideButton(): HTMLElement | null | undefined {
return document.body.querySelector('my-button')?.shadowRoot?.querySelector('button')
}