Setting up Vitest with Next.js
Learn how to set up Vitest with Next.js for Unit Testing.
Vite and React Testing Library are frequently used together for Unit Testing. This guide will show you how to setup Vitest with Next.js and write your first tests.
Good to know: Since async
Server Components are new to the React ecosystem, Vitest currently does not support them. While you can still run unit tests for synchronous Server and Client Components, we recommend using an E2E tests for async
components.
Quickstart
You can use create-next-app
with the Next.js with-vitest example to quickly get started:
Manual Setup
To manually set up Vitest, install vitest
and the following packages as dev dependencies:
Create a vitest.config.mts|js
file in the root of your project, and add the following options:
For more information on configuring Vitest, please refer to the Vitest Configuration docs.
Then, add a test
script to your package.json
:
When you run npm run test
, Vitest will watch for changes in your project by default.
Creating your first Vitest Unit Test
Check that everything is working by creating a test to check if the <Page />
component successfully renders a heading:
Good to know: The example above uses the common __tests__
convention, but test files can also be colocated inside the app
router.
Running your tests
Then, run the following command to run your tests:
Additional Resources
You may find these resources helpful: