resources/assets/js/components/ui/Magnifier.spec.ts

Summary

Maintainability
A
0 mins
Test Coverage
import { expect, it } from 'vitest'
import UnitTestCase from '@/__tests__/UnitTestCase'
import { screen } from '@testing-library/vue'
import Magnifier from './Magnifier.vue'

new class extends UnitTestCase {
  protected test () {
    it('renders and functions', async () => {
      const { html, emitted } = this.render(Magnifier)

      await this.user.click(screen.getByRole('button', { name: 'Zoom in' }))
      expect(emitted().in).toBeTruthy()

      await this.user.click(screen.getByRole('button', { name: 'Zoom out' }))
      expect(emitted().out).toBeTruthy()

      expect(html()).toMatchSnapshot()
    })
  }
}