jest.config.js 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  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. "@testing-library/react": "<rootDir>/node_modules/@testing-library/react",
  60. "@testing-library/dom": "<rootDir>/node_modules/@testing-library/dom",
  61. '@douyinfe/semi-ui(.*)$': '<rootDir>/packages/semi-ui/$1',
  62. '@douyinfe/semi-foundation(.*)$': '<rootDir>/packages/semi-foundation/$1',
  63. '@douyinfe/semi-illustrations(.*)$': '<rootDir>/packages/semi-illustrations/src/$1',
  64. '@douyinfe/semi-icons(.*)$': '<rootDir>/packages/semi-icons/src/$1',
  65. '@douyinfe/semi-json-viewer-core(.*)$': '<rootDir>/packages/semi-json-viewer-core/src/$1',
  66. // 将semi-animation相关的直接指向它的cjs版本,这样不用再走一次babel-jest的编译
  67. '@douyinfe/semi-animation-styled(.*)$': '<rootDir>/packages/semi-animation-styled',
  68. '@douyinfe/semi-animation-react(.*)$': '<rootDir>/packages/semi-animation-react',
  69. '@douyinfe/semi-animation(.*)$': '<rootDir>/packages/semi-animation',
  70. // 'react-dnd': '<rootDir>/node_modules/react-dnd-cjs/lib/index.js',
  71. '@test(.*)$': '<rootDir>/test/$1',
  72. '@storybook/react': '<rootDir>/test/__mocks__/storyMock.js',
  73. // '@storybook/addon-knobs': '<rootDir>/test/__mocks__/storyAddonMock.js',
  74. },
  75. testURL: 'http://localhost',
  76. // 是否收集测试覆盖率
  77. // collectCoverage: true, // 是否收集测试时的覆盖率信息
  78. collectCoverageFrom: [
  79. 'packages/semi-ui/**/*.{js,jsx,mjs,ts,tsx}',
  80. 'packages/semi-foundation/**/*.{js,jsx,mjs,ts,tsx}',
  81. '!packages/semi-ui/scripts/**',
  82. '!packages/semi-ui/types/**',
  83. '!packages/semi-foundation/scripts/**',
  84. '!packages/**/__test__/**',
  85. '!packages/**/_story/**',
  86. "!packages/**/getBabelConfig.js",
  87. "!packages/**/gulpfile.js",
  88. "!packages/**/webpack.config.js",
  89. "!packages/semi-ui/index.ts",
  90. '!packages/**/_test_/**',
  91. '!packages/**/dist/**',
  92. '!packages/semi-ui/locale/**',
  93. ], // 哪些文件需要收集覆盖率信息
  94. coverageDirectory: '<rootDir>/test/coverage', // 输出覆盖信息文件的目录
  95. coveragePathIgnorePatterns: ['/node_modules/', '<rootDir>/packages/*/index.js'], // 统计覆盖信息时需要忽略的文件
  96. // A set of global variables that need to be available in all test environments
  97. globals: {
  98. globalThis: {}
  99. },
  100. };
  101. // 指定需要进行单元测试的文件匹配规则
  102. switch (process.env.type) {
  103. case 'unit':
  104. config.testMatch = ['<rootDir>/packages/semi-ui/**/__test__/**/*.[j|t]s?(x)'];
  105. break;
  106. case 'story':
  107. config.testMatch = ['<rootDir>/packages/semi-ui/**/_story/?(*.)+(stories).[j|t]s?(x)'];
  108. break;
  109. default:
  110. // unit & story
  111. config.testMatch = [
  112. '<rootDir>/packages/semi-ui/**/__test__/**/*.[j|t]s?(x)',
  113. '<rootDir>/packages/semi-ui/**/_story/?(*.)+(stories).[j|t]s?(x)',
  114. ];
  115. break;
  116. }
  117. module.exports = config;