评论
笔记
在探测安全令牌的权限和可利用性时,Github API 响应为 401 Unauthorized。这个令牌可能在某个时候起作用,并且可能因为它不正确地存储在明文 VCS 中,它被滥用或被 Github 本身作为安全措施撤销。 整治
问题
下一步
|
|
使用 Github 插件安装方法使用基本的 Appveyor 设置在emcniece#1上复制了错误行为。 即使具有提升的 Appveyor 管理员权限,似乎也没有任何日志记录来指示此失败。 通过编辑 appveyor.yaml 继续进行故障排除:删除长构建步骤和部署块。 |
|
一段时间后,emcniece#1的初始构建成功了——我认为这与未经授权的部署令牌无关。 查看 Appveyor 发布的 Github 状态, 排长队很不方便,但对于这个问题来说,它们是一个转移注意力的问题——必须修复最新的分支构建,这样 Appveyor 才能在所有开放的 PR 上报告成功。 奇怪的是,正在进行的状态不包含指向活动 Appveyor 构建的链接,Appveyor 更新特定状态的方式肯定出了问题。有问题的状态都是为了重建 接下来,我将使用无操作 PR 测试新的 CI 构建。 |
|
有趣 – 在emcniece#1中,两个构建 ( 我怀疑 Appveyor 项目设置已被更改以创建此行为,或者项目遇到了一些计划限制。 @MitchBradley您能帮助确认https://ci.appveyor.com/project/cheton/cncjs/settings上的设置有任何差异吗?我将发布我成功配置的屏幕截图: |
|
我似乎没有该 Appveyor 帐户的权限。我在 cncjs repo 上的会员身份似乎没有扩展到 appveyor 设置。我会尝试得到@cheton涉及。他在台湾,所以可能要过一段时间才能上网。 |
|
谢谢@MitchBradley. 我想知道你是否可以再检查一件事:
如果是,我们可能会看到 Github 在 Appveyor 使用构建链接更新相同状态之前添加了待定状态。我们还应该看到 Appveyor 已配置为不在 一种解决方法是删除该分支保护状态规则。另一个修复可能是 |
|
|
|
谢谢@cheton这很棒! 当你关注这个主题时,我能问一下这个项目的 CI 愿景是什么吗?我在 PR 中看到许多不同的平台和状态检查。我想知道您是否愿意巩固和改进这些管道和交付流程。 |
|
我从 Travis CI 切换到 Appveyor 和 CircleCI,因为 Travis CI 已经转变为付费模式,它对 OSS 项目不友好,尤其是当你必须进行 macOS 构建时。 对于这个 repo,我将 CircleCI 和 Appveyor 用于不同的目的:
|
|
感谢您的简要介绍。既然我们已经弄清楚了神秘状态,就把问题标记为已关闭! |






描述
由于 Appveyor CI 未报告其中一项检查的完成状态,因此无法合并多个打开的拉取请求。
示例:#708
需要 CI 故障排除:克隆 repo,设置单独的 CI 管道,然后进行测试。