blessing-skin-server/resources/assets/tests/components/Viewer.test.tsx
2020-03-26 10:24:44 +08:00

135 lines
4.3 KiB
TypeScript

import React from 'react'
import { render, fireEvent } from '@testing-library/react'
import { t } from '@/scripts/i18n'
import Viewer, { PICTURES_COUNT } from '@/components/Viewer'
test('custom footer', () => {
const { queryByText } = render(<Viewer isAlex={false}>footer</Viewer>)
expect(queryByText('footer')).toBeInTheDocument()
})
describe('indicator', () => {
it('hidden by default', () => {
const { queryByText } = render(<Viewer skin="skin" isAlex={false} />)
expect(queryByText(t('general.skin'))).not.toBeInTheDocument()
})
it('nothing', () => {
const { queryByText } = render(<Viewer isAlex={false} showIndicator />)
expect(queryByText(t('general.skin'))).not.toBeInTheDocument()
expect(queryByText(t('general.cape'))).not.toBeInTheDocument()
})
it('skin only', () => {
const { queryByText } = render(
<Viewer skin="skin" isAlex={false} showIndicator />,
)
expect(queryByText(t('general.skin'))).toBeInTheDocument()
expect(queryByText(t('general.cape'))).not.toBeInTheDocument()
})
it('cape only', () => {
const { queryByText } = render(
<Viewer cape="cape" isAlex={false} showIndicator />,
)
expect(queryByText(t('general.skin'))).not.toBeInTheDocument()
expect(queryByText(t('general.cape'))).toBeInTheDocument()
})
it('skin and cape', () => {
const { queryByText } = render(
<Viewer skin="skin" cape="cape" isAlex={false} showIndicator />,
)
expect(
queryByText(`${t('general.skin')} & ${t('general.cape')}`),
).toBeInTheDocument()
expect(queryByText(t('general.skin'))).not.toBeInTheDocument()
expect(queryByText(t('general.cape'))).not.toBeInTheDocument()
})
})
describe('actions', () => {
it('toggle run', () => {
const { getByTitle } = render(<Viewer isAlex={false} />)
fireEvent.click(getByTitle(`${t('general.walk')} / ${t('general.run')}`))
})
it('toggle rotation', () => {
const { getByTitle } = render(<Viewer isAlex={false} />)
fireEvent.click(getByTitle(t('general.rotation')))
})
it('toggle pause', () => {
const { getByTitle } = render(<Viewer isAlex={false} />)
const icon = getByTitle(t('general.pause'))
fireEvent.click(icon)
expect(icon).toHaveClass('fa-play')
})
it('reset', () => {
const { getByTitle } = render(<Viewer isAlex={false} />)
fireEvent.click(getByTitle(t('general.reset')))
})
})
describe('background', () => {
it('white', () => {
const { getByTitle, baseElement } = render(<Viewer isAlex={false} />)
fireEvent.click(getByTitle(t('colors.white')))
expect(
baseElement.querySelector<HTMLDivElement>('.card-body')!.style.background,
).toBe('rgb(255, 255, 255)')
})
it('black', () => {
const { getByTitle, baseElement } = render(<Viewer isAlex={false} />)
fireEvent.click(getByTitle(t('colors.black')))
expect(
baseElement.querySelector<HTMLDivElement>('.card-body')!.style.background,
).toBe('rgb(0, 0, 0)')
})
it('white', () => {
const { getByTitle, baseElement } = render(<Viewer isAlex={false} />)
fireEvent.click(getByTitle(t('colors.gray')))
expect(
baseElement.querySelector<HTMLDivElement>('.card-body')!.style.background,
).toBe('rgb(108, 117, 125)')
})
it('previous picture', () => {
const { getByTitle, baseElement } = render(<Viewer isAlex={false} />)
fireEvent.click(getByTitle(t('colors.prev')))
expect(
baseElement.querySelector<HTMLDivElement>('.card-body')!.style.background,
).toStartWith('url')
fireEvent.click(getByTitle(t('colors.prev')))
expect(
baseElement.querySelector<HTMLDivElement>('.card-body')!.style.background,
).toStartWith('url')
})
it('next picture', () => {
const { getByTitle, baseElement } = render(<Viewer isAlex={false} />)
fireEvent.click(getByTitle(t('colors.next')))
expect(
baseElement.querySelector<HTMLDivElement>('.card-body')!.style.background,
).toStartWith('url')
fireEvent.click(getByTitle(t('colors.next')))
expect(
baseElement.querySelector<HTMLDivElement>('.card-body')!.style.background,
).toStartWith('url')
Array.from({ length: PICTURES_COUNT - 1 }).forEach(() => {
fireEvent.click(getByTitle(t('colors.next')))
})
expect(
baseElement.querySelector<HTMLDivElement>('.card-body')!.style.background,
).toStartWith('url')
})
})