Skip to main content
bun test 支持通过报告工具输出不同格式的结果。本文档涵盖内置报告工具以及如何实现你自己的自定义报告工具。

内置报告工具

默认控制台报告工具

默认情况下,bun test 以人类可读的格式将结果输出到控制台:
terminal
test/package-json-lint.test.ts:
 test/package.json [0.88ms]
 test/js/third_party/grpc-js/package.json [0.18ms]
 test/js/third_party/svelte/package.json [0.21ms]
 test/js/third_party/express/package.json [1.05ms]

 4 pass
 0 fail
 4 expect() calls
Ran 4 tests in 1.44ms
当终端不支持颜色时,输出会避免非 ASCII 字符:
terminal
test/package-json-lint.test.ts:
(pass) test/package.json [0.48ms]
(pass) test/js/third_party/grpc-js/package.json [0.10ms]
(pass) test/js/third_party/svelte/package.json [0.04ms]
(pass) test/js/third_party/express/package.json [0.04ms]

 4 pass
 0 fail
 4 expect() calls
Ran 4 tests across 1 files. [0.66ms]

点状报告工具

点状报告工具用 . 表示通过的测试,用 F 表示失败的测试——适合大型测试套件。
terminal
bun test --dots
bun test --reporter=dots

JUnit XML 报告工具

对于 CI/CD 环境,Bun 支持生成 JUnit XML 报告。JUnit XML 是一种被广泛采用的测试结果格式,许多 CI/CD 系统可解析,包括 GitLab、Jenkins 等。

使用 JUnit 报告工具

要生成 JUnit XML 报告,使用 --reporter=junit 标志并配合 --reporter-outfile 指定输出文件:
terminal
bun test --reporter=junit --reporter-outfile=./junit.xml
这将在测试运行完成时,除了常规输出外,还会将 JUnit XML 报告写入指定路径。

通过 bunfig.toml 配置

你也可以在 bunfig.toml 文件中配置 JUnit 报告工具:
bunfig.toml
[test.reporter]
junit = "path/to/junit.xml"  # JUnit XML 报告的输出路径

JUnit 报告中的环境变量

JUnit 报告工具会自动在 XML 输出中以 <properties> 形式包含环境信息,有助于跟踪 CI 环境中的测试运行。 具体会包含以下可用的环境变量:
环境变量属性名称说明
GITHUB_RUN_IDGITHUB_SERVER_URLGITHUB_REPOSITORYCI_JOB_URLciCI 构建信息
GITHUB_SHACI_COMMIT_SHAGIT_SHAcommitGit 提交标识
系统主机名hostname机器主机名
这有助于更方便地追踪某次测试运行对应的环境和代码提交。

当前限制

JUnit 报告工具目前存在一些限制,未来版本将逐步改进:
  • 不包含单个测试的 stdoutstderr 输出
  • 不包含每个测试用例的精确时间戳字段

GitHub Actions 报告工具

Bun test 会自动检测是否在 GitHub Actions 环境中运行,并直接向控制台输出 GitHub Actions 注解。无需额外配置,只需安装 Bun 并运行 bun test 即可。 关于 GitHub Actions 工作流配置示例,请参阅 CLI 文档的 CI/CD 集成 部分。

自定义报告工具

Bun 允许开发者通过扩展 WebKit Inspector 协议中针对测试的特定域,实现自定义测试报告工具。

测试的 Inspector 协议

为了支持测试报告,Bun 在标准 WebKit Inspector 协议基础上,新增了两个自定义域:
  1. TestReporter:报告测试发现、开始和结束事件
  2. LifecycleReporter:报告测试执行中的错误和异常
这些扩展使得你能够构建能实时接收详细测试执行信息的自定义报告工具。

关键事件

自定义报告工具可监听以下关键事件:
  • TestReporter.found:测试被发现时触发
  • TestReporter.start:测试开始运行时触发
  • TestReporter.end:测试完成时触发
  • Console.messageAdded:测试运行中控制台有输出时触发
  • LifecycleReporter.error:出现错误或异常时触发