Turborepo logo

Jest

Jest 是一个常见的测试运行器,拥有庞大的生态系统。与 Turborepo 集成将带来巨大的速度提升。

须知: 

本指南假设你正在使用 create-turbo 或具有类似结构的仓库。

设置

假设我们有一个如下所示的 monorepo

package.json
package.json

jest 安装到你计划拥有测试套件的包中。在本例中,我们将在 web@repo/ui 中进行测试

终端
npm install jest --workspace=web --workspace=@repo/ui --save-dev

apps/webpackages/ui 都有自己的测试套件,因此我们将 test 脚本添加到它们的 package.json

./apps/web/package.json
{
  "name": "web"
  "scripts": {
    "test": "jest"
  },
  "devDependencies": {
    "jest": "latest"
  }
}

在根目录 turbo.json 中,创建一个 test 任务

./turbo.json
{
  "tasks": {
    "test": {}
  }
}

现在,turbo test 可以并行化和缓存每个包的所有测试套件,仅测试已更改的代码。

在监听模式下运行测试

当你正常运行测试套件时,它会完成并输出到 stdout。这意味着你可以使用 Turborepo 缓存它

但是,当你在监听模式下运行测试时,进程永远不会退出。这使得监听任务更像是一个 开发任务

由于这种差异,我们建议指定两个单独的 Turborepo 任务:一个用于运行你的测试,另一个用于在 Jest 的监听模式下运行它们。在你每个工作区的每个 package.json 文件中

./apps/web/package.json
{
  "name": "web"
  "scripts": {
    "test": "jest",
    "test:watch": "jest --watch"
  }
  "devDependencies": {
    "jest": "latest"
  }
}

在根目录 turbo.json

./turbo.json
{
  "tasks": {
    "test": {},
    "test:watch": {
      "cache": false,
      "persistent": true
    }
  }
}

现在,你可以使用全局 turbo 作为 turbo test:watch 或从根目录 package.json 中的脚本运行此任务

终端
turbo test
终端
turbo test:watch

小时

累计节省计算时间
开始使用
远程缓存 →

在本页