Skip to content

命令行界面

命令

vitest

在当前目录中启动 Vitest。在开发环境会自动进入监听(watch)模式,在 CI 环境会自动进入运行(run)模式。

你可以通过添加参数作为过滤器来运行测试文件,比如:

bash
vitest foobar

将仅运行路径中包含 foobar 的测试文件。 此过滤器仅检查包含,不支持正则表达式或 glob 模式(除非你的终端在 Vitest 接收过滤器之前对其进行处理)。

vitest run

在没有监听模式的情况下执行单次运行。

vitest watch

运行所有测试套件,监听变化并在变化时重新运行测试。与没有参数的情况下调用 vitest 一样。在 CI 环境中,此命令将回退到 vitest run

vitest dev

vitest watch 的别名。

仅运行涵盖源文件列表的测试。 适用于静态惰性导入(例如, import('./index.ts') 或者 import index from './index.ts),但不适用于动态导入(例如, import(filepath))。 所有文件都应该相对于根文件夹。

lint-staged 或你的 CI 设置一起运行很有用。

bash
vitest related /src/index.ts /src/hello-world.js

TIP

不要忘记 Vitest 默认情况下以启用的监视模式运行。如果你使用的是 lint-staged 之类的工具,你还应该传递 --run 选项,以便该命令可以正常退出。

js
// .lintstagedrc.js
export default {
  '*.{js,ts}': 'vitest related --run',
}

vitest bench

仅运行 基准 测试,比较性能结果。

选项

选项
-r, --root <path>根路径
-c, --config <path>配置文件的路径
-u, --update更新快照
-w, --watch启用watch模式
-t, --testNamePattern <pattern>使用符合指定 regexp 模式的全名运行测试
--dir <path>扫描测试文件的基本目录
--ui启用用户界面
--open自动打开用户界面 (默认: !process.env.CI)
--api.port [port]自动打开用户界面指定服务器端口。请注意,如果端口已被使用,Vite 会自动尝试下一个可用端口,因此这可能不是服务器最终监听的实际端口。如果为 "true",将设置为 51204
--api.host [host]指定服务器应该监听哪些 IP 地址。设为 0.0.0.0true 则监听所有地址,包括局域网地址和公共地址
--api.strictPort设置为 true 时,如果端口已被使用,则退出,而不是自动尝试下一个可用端口
--silent测试控制台输出
--hideSkippedTests隐藏跳过测试的日志
--reporter <name>指定报告
--outputFile <filename/-s>如果还指定了支持报告程序,则将测试结果写入文件,使用 cac 的点符号表示多个报告程序的单个输出结果 (比如: --outputFile.tap=./tap.txt)
--coverage.all是否在报告中包含所有文件,包括未测试的文件
--coverage.provider <name>选择覆盖范围采集工具,可用值为 "V8"、"istanbul"和 "custom"。
--coverage.enabled启用覆盖范围收集。可使用 --coverage CLI 选项覆盖(默认值:false)。
--coverage.include <pattern>作为 glob 模式包含在覆盖范围内的文件。使用多个模式时,可指定多次(默认值:**)。
--coverage.exclude <pattern>覆盖范围中要排除的文件。使用多个扩展名时,可指定多次(默认情况下: 访问 coverage.exclude
--coverage.extension <extension>包含在覆盖范围内的扩展名。使用多个扩展名时,可指定多次 (默认: [".js", ".cjs", ".mjs", ".ts", ".mts", ".cts", ".tsx", ".jsx", ".vue", ".svelte"])
--coverage.clean运行测试前清除覆盖结果(默认值:true)
--coverage.cleanOnRerun重新运行监视时清理覆盖率报告(默认值:true)
--coverage.reportsDirectory <path>将覆盖率报告写入的目录(默认值: ./coverage)
--coverage.reporter <name>使用的报告。更多信息请访问 coverage.reporter。 (默认值: ["text", "html", "clover", "json"])
--coverage.reportOnFailure即使测试失败也能生成覆盖率报告 (默认值: false)
--coverage.allowExternal收集项目根目录外文件的覆盖范围(默认值:false)
--coverage.skipFull不显示语句、分支和函数覆盖率为 100% 的文件(默认值:false)
--coverage.thresholds.100将所有覆盖率阈值设置为 100 的快捷方式(默认值:false
--coverage.thresholds.perFile检查每个文件的阈值。 --coverage.thresholds.lines, --coverage.thresholds.functions, --coverage.thresholds.branches, --coverage.thresholds.statements 为实际阈值(默认值:false
--coverage.thresholds.autoUpdate更新阈值: 当当前覆盖率高于配置的阈值时,将 "lines"、"functions"、"branches"和 "statements"更新到配置文件(默认值:false
--coverage.thresholds.lines <number>针对代码行的覆盖度阈值设定,请访问 istanbuljs 了解更多信息。此选项不适用于自定义 providers
--coverage.thresholds.functions <number>针对函数的覆盖度阈值设定,请访问 istanbuljs 了解更多信息。 此选项不适用于自定义 providers
--coverage.thresholds.branches <number>针对branches的覆盖度阈值设定,请访问 istanbuljs 了解更多信息。 此选项不适用于自定义 providers
--coverage.thresholds.statements <number>针对statements的覆盖度阈值设定,请访问 istanbuljs 了解更多信息。 此选项不适用于自定义 providers
--coverage.ignoreClassMethods <name>覆盖时要忽略的类方法名称数组。更多信息请访问 istanbuljs 。该选项仅适用于 istanbul providers(默认值:[])。
--coverage.processingConcurrency <number>处理覆盖率结果时使用的并发限制。 (默认最小值介于 20 和 CPU 数量之间)
--coverage.customProviderModule <path>指定自定义覆盖范围提供程序模块的模块名称或路径。 请访问自定义providers覆盖范围 了解更多信息。 此选项仅适用于自定义 providers
--coverage.watermarks.statements <watermarks>High and low watermarks for statements in the format of <high>,<low>
--coverage.watermarks.lines <watermarks>High and low watermarks for lines in the format of <high>,<low>
--coverage.watermarks.branches <watermarks>High and low watermarks for branches in the format of <high>,<low>
--coverage.watermarks.functions <watermarks>High and low watermarks for functions in the format of <high>,<low>
--mode <name>覆盖 Vite 模式 (默认值: testbenchmark)
--workspace <path>工作区配置文件的路径
--isolate隔离运行每个测试文件。要禁用隔离, 使用 --no-isolate (默认值: true)
--globals全局注入
--dom使用 happy-dom 模拟浏览器 API
--browser.enabled在浏览器中运行测试。 相当于 --browser.enabled (默认值: false)
--browser.name <name>在特定浏览器中运行所有测试。某些浏览器只适用于特定的 providers (比如 --browser.provider). 通过 browser.name 查看更多信息
--browser.headless在无头模式下运行浏览器(即不打开图形用户界面)。如果在 CI 中运行 Vitest,默认情况下将启用无头模式 (默认值: process.env.CI)
--browser.api.port [port]指定服务器端口。注意,如果端口已被使用,Vite 会自动尝试下一个可用端口,因此这可能不是服务器最终监听的实际端口。如果为 true,将设置为 63315
--browser.api.host [host]指定服务器应该监听哪些 IP 地址。设为 0.0.0.0true 则监听所有地址,包括局域网地址和公共地址
--browser.api.strictPort设置为 true 时,如果端口已被使用,则退出,而不是自动尝试下一个可用端口
--browser.provider <name>用于运行浏览器测试的Provider。某些浏览器只适用于特定的提供Provider,可以是"webdriverio", "playwright", 或自定义 provider. 通过 browser.provider 查看更多信息 (默认值: "webdriverio")
--browser.providerOptions <options>传递给浏览器 provider. 通过 browser.providerOptions 查看更多信息
--browser.slowHijackESM让Vitest在浏览器环境下使用其内部的模块解析机制来启用APIs。比如 vi.mock and vi.spyOn. 通过 browser.slowHijackESM 查看更多信息 (默认值: false)
--browser.isolate隔离运行每个浏览器测试文件。要禁用隔离请使用 --browser.isolate=false (默认值: true)
--browser.fileParallelism是否所有测试文件都应并行运行。使用 --browser.file-parallelism=false 禁用 (默认值: 比如 --file-parallelism)
--pool <pool>如果未在浏览器中运行,则指定pool (默认值: threads)
--poolOptions.threads.isolate在线程池中隔离测试 (默认值: true)
--poolOptions.threads.singleThread在单线程内运行测试 (默认值: false)
--poolOptions.threads.minThreads <workers>运行测试的最小线程数
--poolOptions.threads.useAtomics使用 Atomics 同步线程。这在某些情况下可以提高性能,但在较旧的 Node 版本中可能会导致 segfault。 (默认值: false)
--poolOptions.vmThreads.isolate在线程池中隔离测试 (默认值: true)
--poolOptions.vmThreads.singleThread在单线程内运行测试(默认值:false
--poolOptions.vmThreads.maxThreads <workers>运行测试的最大线程数
--poolOptions.vmThreads.minThreads <workers>运行测试的最小线程数
--poolOptions.vmThreads.useAtomics使用 Atomics 同步线程。这在某些情况下可以提高性能,但在较旧的 Node 版本中可能会导致 segfault。 (默认值: false)
--poolOptions.vmThreads.memoryLimit <limit>虚拟机线程池的内存限制。如果发现内存泄漏,请尝试调整该值。
--poolOptions.forks.isolate在forks pool 中隔离测试 (默认值: true)
--poolOptions.forks.singleFork单个子进程内运行测试 (default: false)
--poolOptions.forks.maxForks <workers>运行测试的最大进程数
--poolOptions.forks.minForks <workers>运行测试的最小进程数
--poolOptions.vmForks.isolate在forks pool中隔离测试 (default: true)
--poolOptions.vmForks.singleFork在单个子进程内运行测试 (default: false)
--poolOptions.vmForks.maxForks <workers>运行测试的最大进程数
--poolOptions.vmForks.minForks <workers>运行测试的最小进程数
--poolOptions.vmForks.memoryLimit <limit>VM forks pool的内存限制。如果你观察到内存泄漏问题,可以尝试调整这个值。
--fileParallelism是否所有测试文件都应并行运行. 使用 --no-file-parallelism 去禁用 (默认值: true)
--maxWorkers <workers>同时并发执行测试任务的最大线程数
--minWorkers <workers>同时并发执行测试任务的最小线程数
--environment <name>如果不在浏览器中运行,则指定运行环境 (默认值: node)
--passWithNoTests未发现测试时通过
--logHeapUsage在节点中运行时,显示每个测试的堆大小
--allowOnly允许执行那些被标记为"only"的测试用例或测试套件 (默认值: !process.env.CI)
--dangerouslyIgnoreUnhandledErrors忽略任何未处理的错误
--shard <shards>测试套件分区的执行格式为 <index>/<count>
--changed [since]运行受更改文件影响的测试 (默认值: false)
--sequence.shuffle.files以随机顺序运行文件。如果启用此选项,长时间运行的测试将不会提前开始。 (默认值: false)
--sequence.shuffle.tests以随机方式运行测试(默认值:false
--sequence.concurrent使测试并行运行(默认值:false
--sequence.seed <seed>设置随机化种子。如果 --sequence.shuffle(随机序列)是false,则此选项无效。 t通过 "Random Seed" page 查看更多信息
--sequence.hooks <order>更改钩子的执行顺序。 可接受的值有: "stack", "list" and "parallel". 通过 sequence.hooks 查看更多信息 (默认值: "parallel")
--sequence.setupFiles <order>更改设置文件的执行顺序。可接受的值有 "list" 和 "parallel"。如果设置为"list",将按照定义的顺序运行设置文件。如果设置为 "parallel",将并行运行设置文件(默认值:"parallel")。
--inspect [[host:]port]启用 Node.js 检查器(默认值:127.0.0.1:9229
--inspectBrk [[host:]port]启用 Node.js 检查器并在测试开始前中断
--testTimeout <timeout>测试的默认超时(毫秒)(默认值:5000)。
--hookTimeout <timeout>默认钩子超时(以毫秒为单位)(默认值:10000
--bail <number>当指定数量的测试失败时停止测试执行(默认值:0
--retry <times>如果测试失败,重试特定次数(默认值: 0)。
--diff <path>用于生成差异界面的差异配置的路径
--exclude <glob>测试中排除的其他文件路径匹配模式
--expandSnapshotDiff快照失败时显示完整差异
--disableConsoleIntercept禁用自动拦截控制台日志(默认值:false
--typecheck.enabled在测试的同时启用类型检查(默认值:false
--typecheck.only仅运行类型检查测试。这将自动启用类型检查(默认值:false
--typecheck.checker <name>指定要使用的类型检查器。可用值为 "tcs"和 "vue-tsc "以及一个可执行文件的路径(默认值:tsc
--typecheck.allowJs允许对 JavaScript 文件进行类型检查。默认值取自 tsconfig.json
--typecheck.ignoreSourceErrors忽略源文件中的类型错误
--typecheck.tsconfig <path>自定义 tsconfig 文件的路径
--project <name>如果使用 Vitest 工作区功能,则为要运行的项目名称。多个项目可重复此操作: project=1--project=2。也可以使用通配符过滤项目,如 --project=packages*
--slowTestThreshold <threshold>测试速度慢的阈值(以毫秒为单位)(默认值:300
--teardownTimeout <timeout>拆卸函数的默认超时(以毫秒为单位)(默认值:10000
--maxConcurrency <number>套件中并发测试的最大次数(默认值:`5)
--run禁用watch模式
--segfaultRetry <times>如果测试套件因 segfault 而崩溃,则重试测试套件(默认值:true)。
--no-color删除控制台输出中的颜色
--clearScreen在wathc模式下重新运行测试时清除终端屏幕(默认值:true)。

TIP

Vitest 支持 CLI 参数的 both camel case 和 kebab case 。例如,--passWithNoTests--pass-with-no-tests 都有效(--no-color--inspect-brk 是例外)。

Vitest 还支持不同的指定值的方式:--reporter dot--reporter=dot 都是有效的。

如果选项支持值数组,则需要多次传递选项:

bash
vitest --reporter=dot --reporter=default

布尔值选项可以用 no- 前缀来否定。将值指定为 false 也有效:

bash
vitest --no-api
vitest --api=false

changed

  • 类型: boolean | string

  • 默认值: false

    设置为 true 时,仅对已更改的文件运行测试。默认情况下,将考虑所有未提交的更改(包括已暂存和未暂存的文件)。

    要对最近一次提交中的更改运行测试,可以使用 --changed HEAD~1。还可以使用提交哈希(commit hash)或分支名称。

    如果与 forceRerunTriggers 配置选项配合使用,并找到与更改的文件匹配的内容,将运行整个测试套件。

    与代码覆盖一起使用时,报告将只包含与更改相关的文件。

    如果与 forceRerunTriggers配置选项搭配使用,则在 forceRerunTriggers 列表中列出的文件至少有一个发生变化时,将运行整个测试套件。默认情况下,Vitest 配置文件和 package.json 的更改将始终重新运行整个套件。

shard

  • 类型: string

  • 默认值: disabled

    测试套件分片,格式为 <index>/<count>,其中

    • count 是正整数,表示分割的部分数
    • index 是正整数,表示当前分片的索引

    该命令将将所有测试分成 count 个相等的部分,并只运行位于 index 部分的测试。例如,要将测试套件分成三个部分,请使用以下命令:

    sh
    vitest run --shard=1/3
    vitest run --shard=2/3
    vitest run --shard=3/3

警告

无法在启用 --watch(默认情况下在开发中启用)时使用此选项。

Released under the MIT License.