Skip to content

工作空间

Sample Project

GitHub - Play Online

Vitest 通过工作空间配置文件提供了对 monorepos 的内置支持。你可以创建一个工作空间来定义项目的配置。

定义工作空间

一个工作区应该在其根目录下(如果你有配置文件,则与其位于同一文件夹中)有一个名为 vitest.workspacevitest.projects 的文件。Vitest 支持 ts/js/json 扩展名的文件。

工作区配置文件应该有一个默认导出,其中包含一个文件列表或 glob 模式,引用你的项目。例如,如果你有一个名为 packages 的项目文件夹,你可以使用以下配置文件定义一个工作区:

ts
export default ['packages/*']

即使某个文件夹中没有配置文件,Vitest 也会将 packages 文件夹中的每个文件夹视为单独的项目。

WARNING

除非在此配置文件中指定,否则 Vitest 不会将根配置文件视为工作区项目(因此它不会运行在 include 中指定的测试)。

你还可以使用项目的配置文件引用项目:

ts
export default ['packages/*/vitest.config.{e2e,unit}.ts']

该模式仅包括具有包含 e2eunitvitest.config 文件的项目。这些关键字需要在文件扩展名之前出现。

WARNING

如果你正在使用 glob 模式引用文件名,请确保你的配置文件以 vite.configvitest.config 开头。否则,Vitest 将跳过它。

你还可以使用内联配置定义项目。工作区文件支持同时使用这两种语法。

ts
import { defineWorkspace } from 'vitest/config'

// defineWorkspace 会提供一个很好的类型提示开发体验
export default defineWorkspace([
  'packages/*',
  {
    // 添加 "extends" 将两个配置合并到一起
    extends: './vite.config.js',
    test: {
      include: ['tests/**/*.{browser}.test.{ts,js}'],
      // 在使用内联配置的时候,建议定义一个名称
      name: 'happy-dom',
      environment: 'happy-dom',
    },
  },
  {
    test: {
      include: ['tests/**/*.{node}.test.{ts,js}'],
      name: 'node',
      environment: 'node',
    },
  },
])

WARNING

所有项目应该具有唯一的名称。否则,Vitest 会抛出错误。如果你没有在内联配置中提供名称,Vitest 将分配一个数字。如果你没有在使用 glob 语法定义的项目配置中提供名称,Vitest 将默认使用目录名称。

如果你不依赖内联配置,你可以在根目录中创建一个小的 JSON 文件:

json
["packages/*"]

工作区项目不支持所有配置属性。为了获得更好的类型安全性,请在项目配置文件中使用 defineProject 方法而不是 defineConfig 方法:

ts
import { 
defineProject
} from 'vitest/config'
export default
defineProject
({
test
: {
environment
: 'jsdom',
// "reporters" 在项目配置中是不支持的, // 所以会报错
reporters
: ['json'],
}, })

运行测试

要在工作区内运行测试,请在根目录 package.json 中定义一个脚本:

json
{
  "scripts": {
    "test": "vitest"
  }
}

现在可以使用 CLI 运行测试了:

bash
npm run test
bash
yarn test
bash
pnpm run test
bash
bun test

如果只需在单个项目内运行测试,使用 --project CLI 选项:

bash
npm run test --project e2e

TIP

CLI 选项 --project 可多次使用,以筛选出多个项目:

bash
npm run test --project e2e --project unit

配置

没有任何配置选项从根级别的配置文件继承。你可以创建一个共享的配置文件,并将其与项目配置文件合并:

ts
import { defineProject, mergeConfig } from 'vitest/config'
import configShared from '../vitest.shared.js'

export default mergeConfig(
  configShared,
  defineProject({
    test: {
      environment: 'jsdom',
    },
  })
)

defineWorkspace级别,你也可以使用 extends选项来继承根级别配置。

ts
import { defineWorkspace } from 'vitest/config'

export default defineWorkspace([
  {
    extends: './vitest.config.ts',
    test: {
      name: 'unit',
      include: ['**/*.unit.test.ts'],
    },
  },
  {
    extends: './vitest.config.ts',
    test: {
      name: 'integration',
      include: ['**/*.integration.test.ts'],
    },
  },
])

此外,某些配置选项不允许在项目配置中使用。其中最明显的是:

  • coverage: 覆盖率是针对整个工作区进行的。
  • reporters: 仅支持根级别的报告器。
  • resolveSnapshotPath: 仅支持根级别的解析器。
  • 所有其他不影响测试运行器的选项。

TIP

所有不支持在项目配置中使用的配置选项,在 "Config" 页面上都有一个 * 标记。

覆盖率

工作区项目的覆盖率可以直接使用。但是,如果你启用了 all 选项并且在某些项目中使用了非常规扩展名,则需要在根配置文件中使用处理此扩展名的插件。

例如,如果你有一个使用 Vue 文件的包,并且它有自己的配置文件,但是某些文件没有在测试中导入,覆盖率分析将会失败,因为它依赖于根配置而不是项目配置,试图分析未使用文件的使用情况。

Released under the MIT License.