Jenkins + pipeline SonarQube task ‘AX8z8yYQBX52uSHGbNy6‘ status is ‘IN

阅读: 评论:0

Jenkins + pipeline SonarQube task ‘AX8z8yYQBX52uSHGbNy6‘ status is ‘IN

Jenkins + pipeline SonarQube task ‘AX8z8yYQBX52uSHGbNy6‘ status is ‘IN

1.在使用pipeline 来实现Sonarqube自动化代码检测获取质检状态时,一直等不到‘OK’的状态,如下图所示,一开始的执行代码和运行的截图,等待一会之后报超时错误

script {timeout(1) {//这里设置超时时间1分钟,如果Sonar Webhook失败,不会出现一直卡在检查状态//利用Sonar webhook功能通知pipeline代码检测结果,未通过质量阈,pipeline将会faildef qg = waitForQualityGate('SonarQube')//注意:这里waitForQualityGate()中的参数也要与之前SonarQube servers中Name的配置相同if (qg.status != 'OK') {error "未通过Sonarqube的代码质量阈检查,请及时修改!failure: ${qg.status}"}}}


 

 

2.后来反复查看很久,检查了SonarQube的webhook,Jenkins里面配置的Sonarqube服务端和SonarScanner,都没啥问题,最后在 Stack Overflow 的帖子里面,发现这是一个 SonarQube 的bug, 解决方案是在 Sonar Qube状态确认前,先让 SonarQube 跑一会儿,确保 SonarQube Task 成功运行状态。

3.下面时修改后的jenkinsfile脚本和运行截图

script {Integer waitSeconds = 10Integer timeOutMinutes = 10Integer maxRetry = (timeOutMinutes * 60) / waitSeconds as Integer//  未通过代码检查,中断for (Integer i = 0; i < maxRetry; i++) {try {timeout(time: waitSeconds, unit: 'SECONDS') {//利用sonar webhook功能通知pipeline代码检测结果,未通过质量阈,pipeline将会faildef qg = waitForQualityGate()echo "${qg.status}"if (qg.status != 'OK') {error "Sonar quality gate status: ${qg.status}"} else {i = maxRetry}}} catch (Throwable e) {if (i == maxRetry - 1) {throw e}}}}

 

从上面的运行截图可以看到,在第一次获取状态到最后一次成功获取状态中间等待了几十秒钟,所以这中间的时间有个不确定性,不是大家写的不对,是等待的时间不够长,导致了超时

本文发布于:2024-02-03 06:59:56,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170691479549391.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:SonarQube   pipeline   Jenkins   status   task
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23