SwiftLint 安装步骤在 GitHub 操作上失败

问题描述

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

几个月来,我们的工作配置工作得很好,但大约 1.5 周前,事情开始变得不稳定。有时会通过,有时不会。

我们曾经在 run-tests.yml 文件中有这个:

  - name: Install SwiftLint
    run: brew install swiftlint

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 链接 --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

这工作了几天,昨天又出现了。错误日志让我们感到困惑,因此我们决定在这里询问其他人是否也遇到过这种情况以及如何解决错误日志:

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

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

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

==> 正在从 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~coYbjTED2n87I4lbWSM2m9x30C-vrE5rrKHMyAqgTMiPxECz9ml8pMAuxisNNhLVsg2QySRsw5VtIjJi1h0WglzxHai37yV6fnzuuduDzlhPxtFx1jnvNEkpU5~mGg__&Key-Pair-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 链接 --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

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

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

解决方法

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

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

无论如何,现在只需删除链接/安装步骤即可解决此问题。