SwiftLint 安装步骤在 GitHub Actions 上失败

Jan*_*ker 3 continuous-integration homebrew swift swiftlint github-actions

最近 GitHub Actions 发生了一些变化,我们不确定发生了什么或如何解决它。我们正在测试和构建 iOS 应用程序,并使用 SwiftLint 进行自动 PR 检查。

几个月来,我们的工作配置一直运转良好,但大约 1.5 周前,事情开始变得不稳定。有时它贯穿,有时则不贯穿。

我们的文件中曾经有这样的内容run-tests.yml

  - name: Install SwiftLint
    run: brew install swiftlint
Run Code Online (Sandbox Code Playgroud)

9 天前,测试在这一步突然开始失败。以下是来自 GitHub Actions 的日志:

==> 浇注 swiftlint-0.42.0.catalina.bottle.tar.gz

错误:该brew link步骤未成功完成 已构建公式,但未符号链接到 /usr/local 无法符号链接 bin/swiftlint 目标 /usr/local/bin/swiftlint 已存在。您可能想删除它: rm '/usr/local/bin/swiftlint'

要强制链接并覆盖所有冲突的文件:brew link --overwrite swiftlint

列出要删除的所有文件:brew link --overwrite --dry-run swiftlint

可能的冲突文件是:/usr/local/bin/swiftlint

==> 摘要 /usr/local/Cellar/swiftlint/0.42.0:6 个文件,12.2MB 错误:进程已完成,退出代码为 1。

经过一些研究,查看错误消息并看到其他作业成功运行(意味着 SwiftLint 可以正确安装),我们决定设置一个故障保护:尝试链接现有的 SwiftLint,如果失败,只需安装它:

  - name: Link SwiftLint or install it
    run: brew link --overwrite swiftlint || brew install swiftlint
Run Code Online (Sandbox Code Playgroud)

这几天一直有效,昨天又出现了。错误日志让我们感到困惑,因此我们决定在这里询问其他人是否也遇到此问题以及如何解决此问题。错误日志:

运行brew link --overwrite swiftlint || 酿造安装 swiftlint

错误:没有这样的桶:/usr/local/Cellar/swiftlint

==> 下载https://homebrew.bintray.com/bottles/swiftlint-0.42.0.catalina.bottle.tar.gz

==> Downloading from https://d29vzk4ow07wi7.cloudfront.net/e9023ed754eb8cb78a9f2b469a90875ca42a7afffd3e96f8142252e81d889793?response-content-disposition=attachment%3Bfilename%3D%22swiftlint-0.42.0.catalina.bottle.tar.gz%22&Policy=eyJTdGF0ZW1lbnQiOiBbeyJSZXNvdXJjZSI6Imh0dHAqOi8vZDI5dnprNG93MDd3aTcuY2xvdWRmcm9udC5uZXQvZTkwMjNlZDc1NGViOGNiNzhhOWYyYjQ2OWE5MDg3NWNhNDJhN2FmZmZkM2U5NmY4MTQyMjUyZTgxZDg4OTc5Mz9yZXNwb25zZS1jb250ZW50LWRpc3Bvc2l0aW9uPWF0dGFjaG1lbnQlM0JmaWxlbmFtZSUzRCUyMnN3aWZ0bGludC0wLjQyLjAuY2F0YWxpbmEuYm90dGxlLnRhci5neiUyMiIsIkNvbmRpdGlvbiI6eyJEYXRlTGVzc1RoYW4iOnsiQVdTOkVwb2NoVGltZSI6MTYxMTgzMjUzNH0sIklwQWRkcmVzcyI6eyJBV1M6U291cmNlSXAiOiIwLjAuMC4wLzAifX19XX0_&Signature=lH2~FMqNvi1jQxbtgvCFQoZPh3SFuZa3JCgsZ1h3cie4zpArrLUxmRU6OpNk0tgEJ9y3IWpYtBs6xz -NsyeYgZQkbwLGjPA42wBxzT2CfaOgCXlUEK6a7ve5ar7NwOOOUBmr1ypkraZkAP3OVEZ89TFj-ztS8rhGrUNQ3juJOKj11V-SSn07zZVuKwbNsLHqsjHSjqigrRHDng3lQPUE-al~coYbjTED2n87I4 lbWSM2m9x30C-vrE5rrKHMyAqgTMiPxECz9ml8pMAuxisNNhLVsg2QySRsw5VtIjJi1h0WglzxHai37yV6fnzuuduDzlhPxtFx1jnvNEkpU5~mGg__&密钥对 ID=APKAIFKFWOMXM2UMTSFA

==> 浇注 swiftlint-0.42.0.catalina.bottle.tar.gz

错误:该brew link步骤未成功完成 已构建公式,但未符号链接到 /usr/local 无法符号链接 bin/swiftlint 目标 /usr/local/bin/swiftlint 已存在。您可能想删除它: rm '/usr/local/bin/swiftlint'

要强制链接并覆盖所有冲突的文件:brew link --overwrite swiftlint

列出要删除的所有文件:brew link --overwrite --dry-run swiftlint

可能的冲突文件是: /usr/local/bin/swiftlint ==> 摘要 /usr/local/Cellar/swiftlint/0.42.0: 6 个文件,12.2MB

错误:进程已完成,退出代码为 1。

所以首先它说它无法链接现有的 SwiftLint。好的。然后它继续下载它..然后它说它无法链接,因为它已经在那里了?!

当然,我们可以继续尝试以下操作:

  - name: Link SwiftLint or install it
    run: brew link --overwrite swiftlint || brew install swiftlint || brew link --overwrite swiftlint
Run Code Online (Sandbox Code Playgroud)

但这似乎太老套了,必须有更好的解决方案。

非常感谢想法和解决方案。

Jan*_*ker 6

实际上,解决方案似乎非常简单明了。查看 GitHub Actions 的最新虚拟 macOS 环境,我发现 SwiftLint 现在已预安装。

奇怪的是,在某些虚拟机上 Homebrew 能够安装 SwiftLint,而在其他虚拟机上却不能。我希望此步骤要么在所有机器上有效,要么在所有机器上失败。

不管怎样,只需删除链接/安装步骤就可以暂时解决这个问题。