|
| 1 | +const path = require('path') |
| 2 | + |
| 3 | +// When REACT_VERSION is set (e.g. "18.0"), resolve react, react-dom and |
| 4 | +// @testing-library/react from the matching test/react/<version> directory so |
| 5 | +// the test suite runs against that specific React version. |
| 6 | +const generateReactVersionMappings = (reactVersion) => { |
| 7 | + if (!reactVersion) { |
| 8 | + return {} |
| 9 | + } |
| 10 | + |
| 11 | + const testDir = path.join(process.cwd(), 'test', 'react', reactVersion) |
| 12 | + const [major] = reactVersion.split('.').map(Number) |
| 13 | + |
| 14 | + const reactDir = path.dirname( |
| 15 | + require.resolve('react/package.json', { paths: [testDir] }), |
| 16 | + ) |
| 17 | + const reactDomDir = path.dirname( |
| 18 | + require.resolve('react-dom/package.json', { paths: [testDir] }), |
| 19 | + ) |
| 20 | + |
| 21 | + const mappings = { |
| 22 | + '^react$': require.resolve('react', { paths: [testDir] }), |
| 23 | + '^react-dom$': require.resolve('react-dom', { paths: [testDir] }), |
| 24 | + '^react-dom/(.*)$': `${reactDomDir}/$1`, |
| 25 | + '^react/(.*)$': `${reactDir}/$1`, |
| 26 | + } |
| 27 | + |
| 28 | + // React 16 and 17 use @testing-library/react 12.x which does not export |
| 29 | + // renderHook. A shim re-exports it from @testing-library/react-hooks instead. |
| 30 | + if (major < 18) { |
| 31 | + mappings['^@testing-library/react$'] = path.join( |
| 32 | + testDir, |
| 33 | + '..', |
| 34 | + 'testing-library-shim.js', |
| 35 | + ) |
| 36 | + } else { |
| 37 | + mappings['^@testing-library/react$'] = require.resolve( |
| 38 | + '@testing-library/react', |
| 39 | + { paths: [testDir] }, |
| 40 | + ) |
| 41 | + } |
| 42 | + |
| 43 | + return mappings |
| 44 | +} |
| 45 | + |
| 46 | +// React 16 and 17 boundary tests produce harmless "wrong act()" warnings from |
| 47 | +// @testing-library/react-hooks. A setup file suppresses them. |
| 48 | +const generateSetupFiles = (reactVersion) => { |
| 49 | + if (!reactVersion) { |
| 50 | + return [] |
| 51 | + } |
| 52 | + |
| 53 | + const [major] = reactVersion.split('.').map(Number) |
| 54 | + if (major < 18) { |
| 55 | + return [path.join(__dirname, 'setupReact.js')] |
| 56 | + } |
| 57 | + |
| 58 | + return [] |
| 59 | +} |
| 60 | + |
1 | 61 | module.exports = { |
2 | 62 | collectCoverage: true, |
3 | 63 | collectCoverageFrom: ['src/*.{ts,tsx}'], |
4 | 64 | moduleFileExtensions: ['ts', 'tsx', 'js'], |
| 65 | + moduleNameMapper: { |
| 66 | + ...generateReactVersionMappings(process.env.REACT_VERSION), |
| 67 | + }, |
5 | 68 | preset: 'ts-jest', |
6 | 69 | rootDir: process.cwd(), |
7 | 70 | roots: ['<rootDir>/test'], |
| 71 | + setupFilesAfterEnv: generateSetupFiles(process.env.REACT_VERSION), |
8 | 72 | testEnvironment: 'jsdom', |
9 | 73 | testMatch: ['<rootDir>/test/*.spec.ts?(x)'], |
10 | 74 | transform: { '^.+\\.(js|tsx?)$': 'ts-jest' }, |
|
0 commit comments