[ad_1]
Testing is essential for guaranteeing React apps are steady and bug-free. In style instruments like Jest and React Testing Library make testing React parts easy.
Let’s take a look at methods to write nice exams for React:
render Element
Render the part right into a take a look at surroundings utilizing render
from React Testing Library:
import { render } from '@testing-library/react';
import Button from './Button';
take a look at('shows button textual content', () => {
const { getByText } = render(<Button>Click on</Button>);
anticipate(getByText('Click on')).toBeInTheDocument();
});
This renders the part just about for testing.
Hearth Occasions
Simulate consumer occasions like clicks with fireEvent
:
take a look at('calls onClick prop on click on', () => {
const onClick = jest.fn();
const { getByText } = render(<Button onClick={onClick}>Click on</Button>);
fireEvent.click on(getByText('Click on'));
anticipate(onClick).toHaveBeenCalledTimes(1);
});
Assertion Matchers
Use matchers like toBeInTheDocument
to make assertions:
// Assertion passes
anticipate(getByText('Click on')).toBeInTheDocument();
// Assertion fails
anticipate(getByText('Click on')).not.toBeInTheDocument();
Mock Capabilities
Spy on callbacks with mock features:
const handleChange = jest.fn();
// work together with part
anticipate(handleChange).toHaveBeenCalledWith('enter worth');
This enables asserting operate calls.
Abstract
- Use render to mount parts
- Hearth occasions to simulate interplay
- Make assertions with matchers
- Spy on callbacks with mock features
Automated testing leads to sturdy React parts you possibly can refactor with confidence.
[ad_2]