react-testing-library latest and greatest best practices
React testing library has evolved and changed over the last couple of years and so has how we should use it. Here's a list of some of the latest best practices.
The Principles inform the philosophy of the library e.g. "write tests that closely resemble how your web pages are used" by the user.
best practices
- follow the "which query to use guide" and prefer first to use get/queryByRole
- getByTestId() is now the least preferred (informed by Principals)
- import and use screen instead of de-structuring result of render
- @testing-library/user-event is preferred to fireEvent
- userEvent.type()
- fireEvent is not an accurate way for how a users does a click, user-events has all the events which get fired (informed by Principals)
- use eslint-plugin-testing-library because it will call out bad practices and recommends alternatives; helps to keep you up to date with latest
- recommend set everything to warning to start
- screen.debug() can be useful to debug the dom
- screen.logTestingPlaygroundURL()
- generates a url which you can interact with and try queries to use
- there is a browser plugin for this
- within can be used to query within elements
- for composite tests, if you do test then test the binding of the child components
- you can use react-testing-library with cypress which gives you the same principals and code consistency across both e2e and unit tests
Comments
Post a Comment