jest.config.js 5.6 KB

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