默认发现逻辑
默认情况下,bun test 会递归搜索项目目录中符合特定模式的文件:
*.test.{js|jsx|ts|tsx}- 以.test.js、.test.jsx、.test.ts或.test.tsx结尾的文件*_test.{js|jsx|ts|tsx}- 以_test.js、_test.jsx、_test.ts或_test.tsx结尾的文件*.spec.{js|jsx|ts|tsx}- 以.spec.js、.spec.jsx、.spec.ts或.spec.tsx结尾的文件*_spec.{js|jsx|ts|tsx}- 以_spec.js、_spec.jsx、_spec.ts或_spec.tsx结尾的文件
排除项
默认情况下,Bun 测试会忽略:node_modules目录- 隐藏目录(以句点
.开头的目录) - 没有 JavaScript 类扩展名的文件(基于可用的加载器)
自定义测试发现
位置参数作为过滤器
你可以通过向bun test 传递额外的位置参数来过滤运行的测试文件:
terminal
utils 目录下的所有测试:
terminal
src/utils/string.test.ts 和 lib/utils/array_test.js 的文件。
指定精确文件路径
要在测试运行器中运行特定文件,确保路径以./ 或 / 开头,以区别于过滤器名称:
terminal
按测试名称过滤
要根据测试名称而非文件路径过滤测试,使用-t/--test-name-pattern 选项并传入正则表达式模式:
terminal
describe 块标签按空格连接组成的字符串。例如,定义如下测试:
更改根目录
默认情况下,Bun 从当前工作目录开始查找测试文件。你可以通过bunfig.toml 中的 root 选项更改此目录:
bunfig.toml
执行顺序
测试的执行顺序如下:- 测试文件按顺序执行(非并行)
- 每个文件内的测试按照定义顺序顺序执行