vite.config.ts 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. import { configDefaults } from 'vitest/config'
  2. import { defineConfig } from 'vite-plus'
  3. import { entries } from './scripts/aliases.js'
  4. import { playwright } from '@vitest/browser-playwright'
  5. const includeVaporBrowserE2E = process.env.VUE_INCLUDE_VAPOR_BROWSER_E2E === '1'
  6. export default defineConfig({
  7. define: {
  8. __DEV__: process.env.MODE !== 'benchmark',
  9. __TEST__: true,
  10. __E2E_TEST__: false,
  11. __VERSION__: '"test"',
  12. __BROWSER__: false,
  13. __GLOBAL__: false,
  14. __ESM_BUNDLER__: true,
  15. __ESM_BROWSER__: false,
  16. __CJS__: true,
  17. __SSR__: true,
  18. __BENCHMARK__: false,
  19. __FEATURE_OPTIONS_API__: true,
  20. __FEATURE_SUSPENSE__: true,
  21. __FEATURE_PROD_DEVTOOLS__: false,
  22. __FEATURE_PROD_HYDRATION_MISMATCH_DETAILS__: false,
  23. __COMPAT__: true,
  24. },
  25. resolve: {
  26. alias: entries,
  27. },
  28. test: {
  29. globals: true,
  30. pool: 'threads',
  31. setupFiles: 'scripts/setup-vitest.ts',
  32. sequence: {
  33. hooks: 'list',
  34. },
  35. coverage: {
  36. provider: 'v8',
  37. reporter: ['text', 'html'],
  38. include: ['packages/*/src/**'],
  39. exclude: [
  40. 'packages/vue-compat/**',
  41. 'packages/vue/src/dev.ts',
  42. 'packages/vue/src/runtime.ts',
  43. 'packages/vue/src/runtime-with-vapor.ts',
  44. 'packages/vue/src/index-with-vapor.ts',
  45. 'packages/runtime-core/src/profiling.ts',
  46. 'packages/runtime-core/src/featureFlags.ts',
  47. 'packages/runtime-core/src/customFormatter.ts',
  48. 'packages/runtime-core/src/hydrationStrategies.ts',
  49. 'packages/runtime-dom/src/components/Transition*',
  50. 'packages/runtime-vapor/src/components/Transition*',
  51. ],
  52. },
  53. projects: [
  54. {
  55. extends: true,
  56. test: {
  57. name: 'unit-gc',
  58. pool: 'forks',
  59. execArgv: ['--expose-gc'],
  60. include: ['packages/reactivity/__tests__/gc.spec.ts'],
  61. },
  62. },
  63. {
  64. extends: true,
  65. test: {
  66. name: 'unit',
  67. exclude: [
  68. ...configDefaults.exclude,
  69. 'packages/reactivity/__tests__/gc.spec.ts',
  70. '**/e2e/**',
  71. '**/vapor-e2e-test/**',
  72. 'packages/{vue,vue-compat,runtime-dom,runtime-vapor}/**',
  73. ],
  74. },
  75. },
  76. {
  77. extends: true,
  78. test: {
  79. name: 'unit-jsdom',
  80. environment: 'jsdom',
  81. include: [
  82. 'packages/{vue,vue-compat,runtime-dom,runtime-vapor}/**/*.spec.ts',
  83. ],
  84. exclude: [...configDefaults.exclude, '**/e2e/**'],
  85. },
  86. },
  87. {
  88. extends: true,
  89. test: {
  90. name: 'e2e',
  91. environment: 'jsdom',
  92. isolate: true,
  93. include: ['packages/vue/__tests__/e2e/*.spec.ts'],
  94. },
  95. },
  96. // TODO: merge all vapor e2e tests into browser tests and remove this project
  97. {
  98. extends: true,
  99. test: {
  100. name: 'e2e-vapor',
  101. isolate: true,
  102. include: ['packages-private/vapor-e2e-test/__tests__/*.spec.ts'],
  103. exclude: [
  104. 'packages-private/vapor-e2e-test/__tests__/todomvc.spec.ts',
  105. 'packages-private/vapor-e2e-test/__tests__/vdomInterop.spec.ts',
  106. ],
  107. },
  108. },
  109. // This project pulls in built compiler-sfc output, so keep it out of
  110. // unrelated test runs and only enable it for the dedicated e2e script.
  111. // @ts-expect-error
  112. ...(includeVaporBrowserE2E
  113. ? [
  114. {
  115. extends: './packages-private/vapor-e2e-test/vite.config.ts',
  116. root: './packages-private/vapor-e2e-test',
  117. test: {
  118. globals: true,
  119. isolate: true,
  120. name: 'e2e-vapor-browser',
  121. setupFiles: ['./__tests__/setupBrowser.ts'],
  122. browser: {
  123. enabled: true,
  124. provider: playwright({
  125. launchOptions: {
  126. args: process.env.CI
  127. ? ['--no-sandbox', '--disable-setuid-sandbox']
  128. : [],
  129. },
  130. }),
  131. headless: true,
  132. instances: [{ browser: 'chromium' }],
  133. },
  134. include: [
  135. './__tests__/todomvc.spec.ts',
  136. './__tests__/vdomInterop.spec.ts',
  137. ],
  138. },
  139. },
  140. ]
  141. : []),
  142. ],
  143. onConsoleLog(log) {
  144. if (log.startsWith('You are running a development build of Vue.')) {
  145. return false
  146. }
  147. },
  148. },
  149. staged: {
  150. '*.{js,json}': ['vp fmt --no-error-on-unmatched-pattern'],
  151. '*.ts?(x)': ['vp lint --fix', 'vp fmt --no-error-on-unmatched-pattern'],
  152. },
  153. lint: {
  154. categories: {
  155. correctness: 'off',
  156. },
  157. env: {
  158. builtin: true,
  159. },
  160. ignorePatterns: [
  161. '**/dist/',
  162. '**/temp/',
  163. '**/coverage/',
  164. 'dts-build/packages',
  165. ],
  166. overrides: [
  167. {
  168. files: ['**/*.js', '**/*.ts', '**/*.tsx'],
  169. rules: {
  170. 'no-debugger': 'error',
  171. 'no-console': [
  172. 'error',
  173. {
  174. allow: ['warn', 'error', 'info'],
  175. },
  176. ],
  177. 'no-restricted-globals': [
  178. 'error',
  179. 'window',
  180. 'document',
  181. 'module',
  182. 'require',
  183. ],
  184. 'sort-imports': [
  185. 'error',
  186. {
  187. ignoreDeclarationSort: true,
  188. },
  189. ],
  190. '@typescript-eslint/prefer-ts-expect-error': 'error',
  191. '@typescript-eslint/consistent-type-imports': [
  192. 'error',
  193. {
  194. fixStyle: 'inline-type-imports',
  195. disallowTypeAnnotations: false,
  196. },
  197. ],
  198. '@typescript-eslint/no-import-type-side-effects': 'error',
  199. },
  200. },
  201. {
  202. files: ['packages/shared/**'],
  203. rules: {
  204. 'no-restricted-globals': 'off',
  205. },
  206. },
  207. {
  208. files: ['packages/{vue,vue-compat,runtime-*}/**'],
  209. rules: {
  210. 'no-restricted-globals': ['error', 'module', 'require'],
  211. 'oxc/no-optional-chaining': 'error',
  212. },
  213. },
  214. {
  215. files: ['packages/{compiler-*,server-renderer}/**'],
  216. rules: {
  217. 'no-restricted-globals': ['error', 'window', 'document'],
  218. 'oxc/no-const-enum': 'error',
  219. },
  220. },
  221. {
  222. files: [
  223. 'packages-private/template-explorer/**',
  224. 'packages-private/sfc-playground/**',
  225. ],
  226. rules: {
  227. 'no-restricted-globals': ['error', 'module', 'require'],
  228. 'oxc/no-const-enum': 'error',
  229. 'no-console': 'off',
  230. },
  231. },
  232. {
  233. files: ['*.js'],
  234. rules: {
  235. 'no-unused-vars': [
  236. 'error',
  237. {
  238. vars: 'all',
  239. args: 'none',
  240. },
  241. ],
  242. },
  243. },
  244. {
  245. files: [
  246. '**/__tests__/**',
  247. 'packages-private/dts-test/**',
  248. 'packages-private/dts-build-test/**',
  249. ],
  250. rules: {
  251. 'no-console': 'off',
  252. 'no-restricted-globals': 'off',
  253. 'no-unused-vars': 'off',
  254. 'oxc/no-optional-chaining': 'off',
  255. 'no-restricted-syntax': 'off',
  256. },
  257. globals: {
  258. suite: 'writable',
  259. test: 'writable',
  260. describe: 'writable',
  261. it: 'writable',
  262. expectTypeOf: 'writable',
  263. assertType: 'writable',
  264. expect: 'writable',
  265. assert: 'writable',
  266. chai: 'writable',
  267. vitest: 'writable',
  268. vi: 'writable',
  269. beforeAll: 'writable',
  270. afterAll: 'writable',
  271. beforeEach: 'writable',
  272. afterEach: 'writable',
  273. onTestFailed: 'writable',
  274. onTestFinished: 'writable',
  275. },
  276. },
  277. {
  278. files: [
  279. 'scripts/**',
  280. './*.{js,ts}',
  281. 'packages/*/*.js',
  282. 'packages/vue/*/*.js',
  283. 'packages-private/benchmark/*',
  284. 'packages-private/e2e-utils/*',
  285. ],
  286. rules: {
  287. 'no-restricted-globals': 'off',
  288. 'oxc/no-const-enum': 'error',
  289. 'no-console': 'off',
  290. },
  291. },
  292. ],
  293. },
  294. fmt: {
  295. semi: false,
  296. singleQuote: true,
  297. arrowParens: 'avoid',
  298. printWidth: 80,
  299. experimentalSortPackageJson: false,
  300. ignorePatterns: ['dist', 'CHANGELOG*.md', '*.toml'],
  301. },
  302. })