Unit Testing
We use Jest along with React Testing Library to write unit tests for our components in Composable UI.
Naming convention
By default, Jest looks for files that match either of the following criteria:
- Files with the .test.tsor.spec.tsextension.
- Files located in the __tests__directory anywhere in the project.
In Composable UI, the test file are organized in the __tests__ directories and these files have the .test.ts extension.
Running Unit Tests
To run your unit tests, run the following command:
pnpm test
This command runs Jest in watch mode. Jest scans your project for test files and executes the test cases and provides detailed feedback on passed and failed tests. The feedback also includes a coverage report.
Additional Recommendations
- Mocking Dependencies: Use the mocking capabilities provided by Jest to mock external dependencies or modules that are not the focus of your current unit test. This helps isolate the component that you test and ensures reliable and predictable test results.
- Testing Hooks and Asynchronous Operations: Use the utilities provided by react-testing-library to test hooks and handle asynchronous operations, such as waitFor and act. You can also use these utilities to test components that involve state management, side effects, or API calls.
For comprehensive unit tests in your Next.js application, follow these best practices to ensure code correctness, maintain a robust codebase, and catch regressions early in the development process.