jest.config.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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. ], // 哪些文件需要收集覆盖率信息
  52. coverageDirectory: '<rootDir>/test/coverage', // 输出覆盖信息文件的目录
  53. coveragePathIgnorePatterns: ['/node_modules/', '<rootDir>/packages/*/index.js'], // 统计覆盖信息时需要忽略的文件
  54. // A set of global variables that need to be available in all test environments
  55. globals: {
  56. globalThis: {}
  57. },
  58. };
  59. // 指定需要进行单元测试的文件匹配规则
  60. switch (process.env.type) {
  61. case 'unit':
  62. config.testMatch = ['<rootDir>/packages/semi-ui/**/__test__/**/*.[j|t]s?(x)'];
  63. break;
  64. case 'story':
  65. config.testMatch = ['<rootDir>/packages/semi-ui/**/_story/?(*.)+(stories).[j|t]s?(x)'];
  66. break;
  67. default:
  68. // unit & story
  69. config.testMatch = [
  70. '<rootDir>/packages/semi-ui/**/__test__/**/*.[j|t]s?(x)',
  71. '<rootDir>/packages/semi-ui/**/_story/?(*.)+(stories).[j|t]s?(x)',
  72. ];
  73. break;
  74. }
  75. module.exports = config;