jest.config.js 4.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. // node_modules 中需要经过babel-jest处理的模块,在此声明
  2. let ModuleNeedCompile2Cjs = [
  3. 'lodash-es',
  4. 'react-dnd',
  5. 'dnd-core',
  6. 'react-dnd-html5-backend'
  7. ].join('|');
  8. let config = {
  9. // 单元测试环境根目录
  10. // rootDir: path.resolve(__dirname),
  11. verbose: true,
  12. transform: {
  13. // 将.js、jsx后缀的文件使用babel-jest处理
  14. '^.+\\.(js|jsx|mjs|cjs|ts|tsx)$': 'babel-jest',
  15. '^.+\\.svg$': '<rootDir>/test/__mocks__/svgTransform.js',
  16. },
  17. setupFilesAfterEnv: ['<rootDir>/node_modules/jest-enzyme/lib/index.js'],
  18. // 运行测试前可运行的脚本,比如注册enzyme的兼容
  19. setupFiles: ['<rootDir>/test/setup.js', 'jest-date-mock'],
  20. testEnvironment: 'jsdom',
  21. // 忽略出lodash-es、react-dnd、dnd-core外的node_modules中的所有内容,即node_modules中只有lodash-es、react-dnd、dnd-core需要被babel-jest处理
  22. transformIgnorePatterns: [`<rootDir>/node_modules/(?!(${ModuleNeedCompile2Cjs}))`],
  23. snapshotSerializers: ['enzyme-to-json/serializer'],
  24. // moduleDirectories: ["node_modules"],
  25. moduleNameMapper: {
  26. '\\.(css|scss)$': '<rootDir>/test/__mocks__/styleMock.js',
  27. '\\.(jpg|jpeg|png|gif|eot|otf|webp|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$':
  28. '<rootDir>/test/__mocks__/fileMock.js',
  29. '@douyinfe/semi-ui(.*)$': '<rootDir>/packages/semi-ui/$1',
  30. '@douyinfe/semi-foundation(.*)$': '<rootDir>/packages/semi-foundation/$1',
  31. '@douyinfe/semi-illustrations(.*)$': '<rootDir>/packages/semi-illustrations/src/$1',
  32. '@douyinfe/semi-icons(.*)$': '<rootDir>/packages/semi-icons/src/$1',
  33. // 将semi-animation相关的直接指向它的cjs版本,这样不用再走一次babel-jest的编译
  34. '@douyinfe/semi-animation-styled(.*)$': '<rootDir>/packages/semi-animation-styled',
  35. '@douyinfe/semi-animation-react(.*)$': '<rootDir>/packages/semi-animation-react',
  36. '@douyinfe/semi-animation(.*)$': '<rootDir>/packages/semi-animation',
  37. // 'react-dnd': '<rootDir>/node_modules/react-dnd-cjs/lib/index.js',
  38. '@test(.*)$': '<rootDir>/test/$1',
  39. '@storybook/react': '<rootDir>/test/__mocks__/storyMock.js',
  40. // '@storybook/addon-knobs': '<rootDir>/test/__mocks__/storyAddonMock.js',
  41. },
  42. testURL: 'http://localhost',
  43. // 是否收集测试覆盖率
  44. // collectCoverage: true, // 是否收集测试时的覆盖率信息
  45. collectCoverageFrom: [
  46. 'packages/semi-ui/**/*.{js,jsx,mjs,ts,tsx}',
  47. 'packages/semi-foundation/**/*.{js,jsx,mjs,ts,tsx}',
  48. '!packages/semi-ui/scripts/**',
  49. '!packages/semi-ui/types/**',
  50. '!packages/semi-foundation/scripts/**',
  51. '!packages/**/__test__/**',
  52. '!packages/**/_story/**',
  53. "!packages/**/getBabelConfig.js",
  54. "!packages/**/gulpfile.js",
  55. "!packages/**/webpack.config.js",
  56. "!packages/semi-ui/index.ts",
  57. '!packages/**/_test_/**',
  58. '!packages/**/dist/**',
  59. '!packages/semi-ui/locale/**',
  60. ], // 哪些文件需要收集覆盖率信息
  61. coverageDirectory: '<rootDir>/test/coverage', // 输出覆盖信息文件的目录
  62. coveragePathIgnorePatterns: ['/node_modules/', '<rootDir>/packages/*/index.js'], // 统计覆盖信息时需要忽略的文件
  63. // A set of global variables that need to be available in all test environments
  64. globals: {
  65. globalThis: {}
  66. },
  67. };
  68. // 指定需要进行单元测试的文件匹配规则
  69. switch (process.env.type) {
  70. case 'unit':
  71. config.testMatch = ['<rootDir>/packages/semi-ui/**/__test__/**/*.[j|t]s?(x)'];
  72. break;
  73. case 'story':
  74. config.testMatch = ['<rootDir>/packages/semi-ui/**/_story/?(*.)+(stories).[j|t]s?(x)'];
  75. break;
  76. default:
  77. // unit & story
  78. config.testMatch = [
  79. '<rootDir>/packages/semi-ui/**/__test__/**/*.[j|t]s?(x)',
  80. '<rootDir>/packages/semi-ui/**/_story/?(*.)+(stories).[j|t]s?(x)',
  81. ];
  82. break;
  83. }
  84. module.exports = config;