blessing-skin-server/resources/assets/tests/views/auth/Registration.test.tsx
2020-05-30 10:44:36 +08:00

141 lines
4.1 KiB
TypeScript

import React from 'react'
import { render, waitFor, fireEvent } from '@testing-library/react'
import { t } from '@/scripts/i18n'
import * as fetch from '@/scripts/net'
import urls from '@/scripts/urls'
import Registration from '@/views/auth/Registration'
jest.mock('@/scripts/net')
beforeEach(() => {
window.blessing.extra = { player: false }
})
test('confirmation is not matched', () => {
const { getByText, getByPlaceholderText, queryByText } = render(
<Registration />,
)
fireEvent.input(getByPlaceholderText(t('auth.email')), {
target: { value: 'a@b.c' },
})
fireEvent.input(getByPlaceholderText(t('auth.password')), {
target: { value: 'password' },
})
fireEvent.input(getByPlaceholderText(t('auth.repeat-pwd')), {
target: { value: 'password1' },
})
fireEvent.input(getByPlaceholderText(t('auth.nickname')), {
target: { value: 't' },
})
fireEvent.input(getByPlaceholderText(t('auth.captcha')), {
target: { value: 'a' },
})
fireEvent.click(getByText(t('auth.register-button')))
expect(queryByText(t('auth.invalidConfirmPwd'))).toBeInTheDocument()
expect(fetch.post).not.toBeCalled()
})
test('succeeded', async () => {
fetch.post.mockResolvedValue({ code: 0, message: 'ok' })
const { getByText, getByPlaceholderText, getByRole, queryByText } = render(
<Registration />,
)
fireEvent.input(getByPlaceholderText(t('auth.email')), {
target: { value: 'a@b.c' },
})
fireEvent.input(getByPlaceholderText(t('auth.password')), {
target: { value: 'password' },
})
fireEvent.input(getByPlaceholderText(t('auth.repeat-pwd')), {
target: { value: 'password' },
})
fireEvent.input(getByPlaceholderText(t('auth.nickname')), {
target: { value: 't' },
})
fireEvent.input(getByPlaceholderText(t('auth.captcha')), {
target: { value: 'a' },
})
fireEvent.click(getByText(t('auth.register-button')))
await waitFor(() =>
expect(fetch.post).toBeCalledWith(urls.auth.register(), {
email: 'a@b.c',
password: 'password',
nickname: 't',
captcha: 'a',
}),
)
expect(queryByText('ok')).toBeInTheDocument()
expect(getByRole('status')).toHaveClass('alert-success')
jest.runAllTimers()
})
test('failed', async () => {
fetch.post.mockResolvedValue({ code: 1, message: 'failed' })
const { getByText, getByPlaceholderText, queryByText } = render(
<Registration />,
)
fireEvent.input(getByPlaceholderText(t('auth.email')), {
target: { value: 'a@b.c' },
})
fireEvent.input(getByPlaceholderText(t('auth.password')), {
target: { value: 'password' },
})
fireEvent.input(getByPlaceholderText(t('auth.repeat-pwd')), {
target: { value: 'password' },
})
fireEvent.input(getByPlaceholderText(t('auth.nickname')), {
target: { value: 't' },
})
fireEvent.input(getByPlaceholderText(t('auth.captcha')), {
target: { value: 'a' },
})
fireEvent.click(getByText(t('auth.register-button')))
await waitFor(() =>
expect(fetch.post).toBeCalledWith(urls.auth.register(), {
email: 'a@b.c',
password: 'password',
nickname: 't',
captcha: 'a',
}),
)
expect(queryByText('failed')).toBeInTheDocument()
})
test('register with new player', async () => {
window.blessing.extra = { player: true }
fetch.post.mockResolvedValue({ code: 0, message: 'ok' })
const { getByText, getByPlaceholderText, queryByText } = render(
<Registration />,
)
fireEvent.input(getByPlaceholderText(t('auth.email')), {
target: { value: 'a@b.c' },
})
fireEvent.input(getByPlaceholderText(t('auth.password')), {
target: { value: 'password' },
})
fireEvent.input(getByPlaceholderText(t('auth.repeat-pwd')), {
target: { value: 'password' },
})
fireEvent.input(getByPlaceholderText(t('auth.player-name')), {
target: { value: 'player' },
})
fireEvent.input(getByPlaceholderText(t('auth.captcha')), {
target: { value: 'a' },
})
fireEvent.click(getByText(t('auth.register-button')))
await waitFor(() =>
expect(fetch.post).toBeCalledWith(urls.auth.register(), {
email: 'a@b.c',
password: 'password',
player_name: 'player',
captcha: 'a',
}),
)
expect(queryByText('ok')).toBeInTheDocument()
})