首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SonarCloud分析任务在Azure DevOps PR管道中失败

SonarCloud分析任务在Azure DevOps PR管道中失败
EN

Stack Overflow用户
提问于 2021-05-12 17:44:37
回答 2查看 1.1K关注 0票数 0

我有一个管道在Azure DevOps,这是由公关请求。在这个管道中有三个SonarCloud任务-准备对SonarCloud的分析,(我的项目构建步骤在这里),运行代码分析,然后发布质量门结果。

当这个管道由PR触发时,在到达Run Code Analysis任务之前,这一切都很好,然后运行代码分析任务就会失败,下面的错误消息如下:

代码语言:javascript
复制
INFO: ------------------------------------------------------------------------
INFO: EXECUTION FAILURE
INFO: ------------------------------------------------------------------------
INFO: Total time: 9.173s
INFO: Final Memory: 7M/48M
INFO: ------------------------------------------------------------------------
##[error]ERROR: Error during SonarScanner execution
ERROR: Error during SonarScanner execution
##[error]ERROR: Not authorized. Please check the properties sonar.login and sonar.password.
ERROR:
ERROR: Not authorized. Please check the properties sonar.login and sonar.password.
ERROR: 
##[error]The SonarScanner did not complete successfully
The SonarScanner did not complete successfully
##[error]18:32:43.506  Post-processing failed. Exit code: 1
18:32:43.506  Post-processing failed. Exit code: 1

事情是这样的:每当同一条管道不是由PR触发时,无论是手动的还是自动的,它都在任何分支上运行和通过,没有任何问题。如果我触发分支被拉入的管道(不是通过PR),它运行并通过良好。

为什么授权只有在由PR触发时才会失败?!为什么它不使用来自SonarCloud的相同PAT令牌,而相同的管道在手动触发时使用??

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-05-15 08:40:23

现在我找到了答案,问题是Azure DevOps发布的PAT没有在SonarCloud上设置正确的位置。我把它放在SonarCloud项目管理->常规设置->拉请求->个人访问令牌中,而实际上它应该存储在SonarCloud ->管理组织设置-> Azure DevOps连通性管理->个人访问令牌中,如下所示:

票数 0
EN

Stack Overflow用户

发布于 2021-05-13 06:27:55

为什么授权只有在由PR触发时才会失败?!为什么它不使用来自SonarCloud的相同PAT令牌,而相同的管道在手动触发时使用??

根据描述,PAT似乎没有足够的权限。

您可以尝试使用完全访问更新PAT以测试:

更新SonarCloud中的PAT。

您可以查看本文件以获得更多细节。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67508625

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档