Я создаю приложение React с использованием TypeScript. Я делаю свои тесты компонентов, используя React Testing Library.
Допустим, у вас есть такая простая форма:
import React from 'react'
function Login({onSubmit}) {
return (
<div>
<form
onSubmit={e => {
e.preventDefault()
const {username, password} = e.target.elements
onSubmit({
username: username.value,
password: password.value,
})
}}
>
<label htmlFor="username">Username</label>
<input id="username" />
<label htmlFor="password">Password</label>
<input id="password" type="password" />
<br />
<button type="submit">Submit</button>
</form>
</div>
)
}
export {Login}
В это видео Кент (создатель библиотеки) показывает, как вы будете тестировать входные данные форм. Тесты будут выглядеть так:
import React from 'react'
import {renderIntoDocument, cleanup} from 'react-testing-library'
import {Login} from '../login'
afterEach(cleanup)
test('calls onSubmit with username and password', () => {
const handleSubmit = jest.fn()
const {getByLabelText, getByText} = renderIntoDocument(
<Login onSubmit={handleSubmit} />,
)
getByLabelText(/username/i).value = 'chuck'
getByLabelText(/password/i).value = 'norris'
getByText(/submit/i).click()
expect(handleSubmit).toHaveBeenCalledTimes(1)
expect(handleSubmit).toHaveBeenCalledWith({
username: 'chuck',
password: 'norris',
})
})
Проблема в том, что он сделал это с простым JavaScript. Делая это с
Напечатайте строки, в которых он устанавливает .value
, выдают следующие ошибки
[ts] Property 'value' does not exist on type 'HTMLElement'.
Как можно протестировать эту функциональность с TypeScript, используя React Testing Library? Как бы вы установили значения входа?