Para configurar Testing Library y Jest para su uso con Next.js, TypeScript y CSS Modules, se deben seguir los siguientes pasos:
npm install --save-dev jest babel-jest @testing-library/react @testing-library/jest-dom identity-obj-proxy react-test-renderer
npm install --save-dev @babel/pree-next\basement-challenge>set-env
npm install --save-dev @babel/pree-next\basement-challenge>set-react
npm install --save-dev @babel/preset-typescript
npm install --dev babel-jest jest-css-modules-transform
npm install -D jest-environment-jsdom
module.exports = {
collectCoverageFrom: ['**/*.{js,jsx,ts,tsx}', '!**/*.d.ts', '!**/node_modules/**'],
moduleNameMapper: {
/* Handle CSS imports and with CSS modules
https://jestjs.io/docs/webpack#mocking-css-modules */
'^.+\\.module\\.(css|sass|scss)$': 'identity-obj-proxy',
'^@/(.*)$': '<rootDir>/$1',
// Handle CSS imports without CSS modules
// '^.+\\.(css|sass|scss)$': '<rootDir>/__mocks__/styleMock.js',
/* Handle image imports
https://jestjs.io/docs/webpack#handling-static-assets */
'^.+\\.(jpg|jpeg|png|gif|webp|avif|svg)$': '<rootDir>/__mocks__/fileMock.js',
},
testPathIgnorePatterns: ['<rootDir>/node_modules/', '<rootDir>/.next/'],
testEnvironment: 'jsdom',
transform: {
// '^.+\\.(js|jsx|ts|tsx)$': ['babel-jest', { presets: ['next/babel'] }],
'^.+\\.[jt]sx?$': 'babel-jest',
'.+\\.(css|styl|less|sass|scss)$': 'jest-css-modules-transform',
},
transformIgnorePatterns: ['/node_modules/', '^.+\\.module\\.(css|sass|scss)$'],
testMatch: ['**/__tests__/**/*.[jt]s?(x)', '**/?(*.)+(spec|test|tests).[tj]s?(x)'],
setupFilesAfterEnv: ['<rootDir>/jest.setup.js'],
}
import '@testing-library/jest-dom/extend-expect'
// react sin nextjs, si da error cambiar por '/test-file-stub'
module.exports = 'test-file-stub'
// react con nextjs
module.exports = {
src: '/img.jpg',
height: 24,
width: 24,
blurDataURL: '',
}
module.exports = {}
{
"presets": [
"@babel/preset-env",
["@babel/preset-react", { "runtime": "automatic" }],
"@babel/preset-typescript"
]
}
Con estas configuraciones, Jest y Testing Library estarán listos para ser utilizados en tu proyecto Next.js con TypeScript y CSS Modules.
Tengo otro post sobre cómo hacerle testing a un formulario en react aquí