jest.config.js 5.9 KB

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