This is how you should test 🧪 your react-native ⚛️ components with Jest and React Native Testing Library
In this repo you'll find several examples that will cover:
- 👆 Clicking buttons and asserting onPress' outcome.
- 📲 Filling a simple login form and asserting successful submission.
- 🎣 Custom hook testing (number of alternatives).
- 📡 Mocking fetch calls.
- 🧭 Mocking navigation through screens. (react navigation v5)
- 🔚 E2E feel due to real navigation throughout screens.
- 📥 Handling and mocking providers.
- 📹 Mocking external lib.'s components.
- 🎭 Mocking and interacting with RN's Modal component.
- 🧾 Handling with a screen with RN's FlatList component.
- 📡 Using MSW to mock api calls and handling loading/errors.
- Clone the repo
- Run
yarn
to install dependencies - Run
yarn test
to run the tests - Run
yarn test:coverage
to run the tests and generate a coverage report
- Clone the repo
- Run
yarn
to install dependencies - Run
npx pod-install
to install iOS dependencies - Run
yarn start
to start the metro bundler - Click
i
to run the app on iOS simulator ora
to run it on Android emulator
- 📱 Add E2E tests with Maestro
- ⚛️ Add tests for react native web project
- 📑 A blog by Steve Galili on "Where and How to Start Testing Your React Native App"
- 👏 Inspired by Kent C. Dodds' workshop Test React Components with Jest and React Testing Library. For more info check Epic React.
- 📕 React Native Testing Library
- 🧑🔬️ Jest
- ️⚛️ React Native
- 🗺 React Navigation
- 🛰 MSW