插件 API 3.1.0+
Vitest 自 3.1 版起支持实验性的 configureVitest
插件 hook。欢迎在 GitHub 中提供有关此 API 的任何反馈。
import type { Vite, VitestPluginContext } from 'vitest/node'
export function plugin(): Vite.Plugin {
return {
name: 'vitest:my-plugin',
configureVitest(context: VitestPluginContext) {
// ...
}
}
}
/// <reference types="vitest/config" />
import type { Plugin } from 'vite'
export function plugin(): Plugin {
return {
name: 'vitest:my-plugin',
transform() {
// ...
},
configureVitest(context) {
// ...
}
}
}
TypeScript
Vitest 通过 Vite
namespace 重新导出所有仅 Vite 类型的导入,我们可以使用它来保持版本同步。但是,如果我们正在为 Vite 和 Vitest 编写插件,则可以继续使用 vite
入口点的 Plugin
类型。只需确保我们在某处引用了 vitest/config
,以便正确增强 configureVitest
即可:
/// <reference types="vitest/config" />
与 reporter.onInit
不同,此 hooks 在 Vitest 生命周期的早期运行,允许我们更改 coverage
和 reporters
等配置。更值得注意的变化是,如果我们的插件是在项目中定义而不是在全局配置中定义的,我们可以从 工作区项目 操作全局配置。
Context
project
该插件所属的当前测试项目。
浏览器模式
请注意,如果我们依赖浏览器功能,则 project.browser
字段尚未设置。请改用 reporter.onBrowserInit
事件。
vitest
全局的 Vitest 实例。我们可以直接改变 vitest.config
属性来更改全局配置:
vitest.config.coverage.enabled = false
vitest.config.reporters.push([['my-reporter', {}]])
Config is Resolved
请注意,Vitest 已经解析了配置,因此某些类型可能与通常的用户配置不同。这也意味着某些属性将不会再次解析,例如 setupFile
。如果我们要添加新文件,请确保先解析它。
此时尚未创建记者,因此修改 vitest.reporters
将不起作用,因为它将被覆盖。如果我们需要注入自己的记者,请修改配置。
injectTestProjects
function injectTestProjects(
config: TestProjectConfiguration | TestProjectConfiguration[]
): Promise<TestProject[]>
此方法接受配置 glob 模式、配置的文件路径或内联配置。它返回已解析的 测试项目 数组。
// inject a single project with a custom alias
const newProjects = await injectTestProjects({
// you can inherit the current project config by referencing `configFile`
// note that you cannot have a project with the name that already exists,
// so it's a good practice to define a custom name
configFile: project.vite.config.configFile,
test: {
name: 'my-custom-alias',
alias: {
customAlias: resolve('./custom-path.js'),
},
},
})
Projects are Filtered
Vitest 在配置解析期间过滤项目,因此如果用户定义了过滤器,则注入的项目可能无法解析,除非它 与 filter 匹配。我们可以通过 vitest.config.project
选项更新过滤器,以始终包含我们的工作区项目:
vitest.config.project.push('my-project-name')
请注意,这只会影响使用 injectTestProjects
方法注入的项目。
Referencing the Current Config
如果我们想保留用户配置,可以指定 configFile
属性。所有其他属性都将与用户定义的配置合并。
项目的 configFile
可以在 Vite 的配置中访问:project.vite.config.configFile
。
请注意,这也将继承 name
- Vitest 不允许多个项目使用相同的名称,因此这将引发错误。请确保我们指定了不同的名称。我们可以通过 project.name
属性访问当前名称,并且所有使用的名称都可以在 vitest.projects
数组中找到。