当我尝试升级某些依赖项时,为什么Yarn抛出“ Invariant Violation:预期的工作空间包存在”?

问题描述

我有一个管理的monorepo,它依赖于Yarn工作区功能。看起来像这样:

/repo
  |-- packages
  |   |-- pkg-a
  |   |   |-- package.json
  |   |-- pkg-b
  |   |   |-- package.json
  |   |-- pkg-c
  |   |   |-- package.json
  |-- package.json

我使用yarn upgrade-interactive更新了我的软件包中的一系列依存关系,但出现此错误

Invariant Violation: expected workspace package to exist for "@babel/plugin-transform-classes"

但这不是我的直接依赖。当我在所有package.json文件中进行搜索时,我什么也没得到:

$ find . -name "package.json" -and -not -path "*/node_modules/*" | xargs grep "@babel/plugin-transform-classes"
$

尽管它存在于我的yarn.lock文件中:

$ grep "@babel/plugin-transform-classes" yarn.lock
"@babel/plugin-transform-classes@^7.10.4":
  resolved "https://registry.yarnpkg.com/@babel/plugin-transform-classes/-/plugin-transform-classes-7.10.4.tgz#405136af2b3e218bc4a1926228bc917ab1a0adc7"
"@babel/plugin-transform-classes@^7.4.0":
  resolved "https://registry.yarnpkg.com/@babel/plugin-transform-classes/-/plugin-transform-classes-7.4.0.tgz#e3428d3c8a3d01f33b10c529b998ba1707043d4d"
    "@babel/plugin-transform-classes" "^7.4.0"
    "@babel/plugin-transform-classes" "^7.10.4"
$

我怀疑存在某种缓存问题,因此我尝试从Docker容器中重新开始:

  1. 删除所有node_modules文件
  2. 将存储库安装在Docker容器中
  3. 运行yarn以安装所有依赖项
  4. 运行yarn upgrade-interactive

但是我得到完全相同的错误

我一直在寻找答案,但是都没有解决我的问题。最让我印象深刻的是,似乎没有人知道为什么为什么

任何人都可以解释为什么会发生这种情况以及如何重现此问题吗?一旦知道原因,我们就有更好的机会找到合适的解决方案。

技术细节:

  • 节点12.18
  • 纱线1.22
  • 莱娜3.20

解决方法

好像是个bug

https://github.com/yarnpkg/yarn/issues/7734#issuecomment-580012389

而官方建议是降级到 Yarn 1.19.x 或手动升级包(Yarn 1 已弃用)。

https://github.com/yarnpkg/yarn/issues/7734#issuecomment-671729912

另外,您可以尝试使用 https://www.npmjs.com/package/npm-check-updates CLI 实用程序