I'm in a Vite/React/TypeScript application and I'm configuring my first test with Vitest.
When I run my Button test (yarn vitest), I get this error:
packages/frontend/src/components/Generic/Button/Button.test.tsx > Button > should render the button
ReferenceError: document is not defined
I understand that Vitest does not work with JSDom. I have tried several things:
I would prefere use the first option (use vite.config.ts) to share only one configuration. Is it possible ?
Note 1 : JSdom i already installed has "devDependencies".
Note 2 : to use vitest.config.ts i should update the script in package.json like that :
"test": "vitest --config ./packages/frontend/vitest.config.ts"
Here are my files:
// vite.config.ts
import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
import viteTsConfigPaths from 'vite-tsconfig-paths'
import tailwindcss from 'tailwindcss'
export default defineConfig({
server: {
port: 4200,
host: 'localhost',
},
rollupOption: {
external: ['@internals/components/index']
},
define: {
global: {},
},
plugins: [
react(),
tailwindcss(),
viteTsConfigPaths({
root: '../../',
}),
],
resolve: {
alias: {
// runtimeConfig is a special alias that is used to import the correct config file
'./runtimeConfig': './runtimeConfig.browser',
// public alias
'@publics': `${__dirname}/public`,
// only internals (private) aliases are allowed here
'@internals/components': `${__dirname}/src/components`,
'@internals/features': `${__dirname}/src/features`,
'@internals/hooks': `${__dirname}/src/hooks`,
'@internals/models': `${__dirname}/src/models`,
'@internals/utils': `${__dirname}/src/utils`,
'@internals/types': `${__dirname}/src/types`,
'@internals/styles': `${__dirname}/src/styles`,
'@internals/assets': `${__dirname}/src/assets`,
'@internals/store': `${__dirname}/src/store`,
'@internals/config': `${__dirname}/src/config`,
'@internals/services': `${__dirname}/src/services`,
},
},
test: {
globals: true,
cache: {
dir: '../../node_modules/.vitest',
},
environment: 'jsdom',
include: ['*.tsx', '*.ts', '*.jsx', '*.js'],
},
})
I tried to add a like this vitest.config.ts :
import { defineConfig } from 'vitest/config'
export default defineConfig({
test: {
include: ['*.ts', '*.tsx'], // FIXME
environment: 'jsdom',
},
})
Vitest runs in a NodeJS environment by default. It has (experimental for now) browser env support though.
If you try to access document in a Node environment, you get:
Uncaught ReferenceError: document is not defined
Please refer to the docs to setup a browser environment if you need to access document:
https://vitest.dev/config/#browser
https://vitest.dev/guide/browser/
to enable JSDom:
install (as dev deps) @testing-library/jest-dom (also @types/testing-library__jest-dom if using Typescript), and jsdom
create a setup-tests.ts file with:
import '@testing-library/jest-dom'
setup-tests.ts:
import { expect } from 'vitest'
import * as matchers from '@testing-library/jest-dom/matchers'
expect.extend(matchers)
export default defineConfig({
test: {
setupFiles: ['./setup-tests.ts'],
globals: true,
environment: 'jsdom',
},
})
compilerOptions, add "types": ["vitest/globals","@testing-library/jest-dom"]
reference: https://vitaneri.com/posts/setting-up-vitest-testing-library-and-jest-dom-in-your-vite-project
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With