1.应用场景
a. 通过调用sonar 检测获取代码的覆盖率以及质量检测集成到devops流程的cicd中,完成自动识别代码质量检测标准
使用python脚本实现(通过sonar的api调用获取)
import requests
import sys
appname = sys.argv[1]
# appname = "besp-scsg-app"
# SonarQube 服务器的基本 URL
sonar_url = "http://10.41.13.12:32428"
# 项目的 Key,可以在 SonarQube 界面上找到
project_key = appname
# 登录 SonarQube 的用户名和密码
username = "admin"
password = "123456"
# SonarQube API 端点
api_endpoint = "/api/measures/component"
# 要获取的度量指标(例如覆盖率)
metric_key = "coverage"
# 构建 API 请求 URL
api_url = f"{sonar_url}{api_endpoint}?component={project_key}&metricKeys={metric_key}"
# 使用 requests 库发送 API 请求,并使用用户名和密码进行身份验证
response = requests.get(api_url, auth=(username, password))
# 检查响应状态码
if response.status_code == 200:
# 解析 JSON 响应
data = response.json()
# 提取覆盖率信息
coverage = None
# 在 SonarQube 6.0 版本中,覆盖率信息的提取方式可能需要根据实际返回的 JSON 结构进行调整
for measure in data["component"]["measures"]:
if measure["metric"] == metric_key:
coverage = measure["value"]
break
if coverage is not None:
# print(f"Coverage: {coverage}%")
if float(coverage) >= 80:
# results = {"code": 200, "message": "sonar覆盖率通过", "data": "%s"%float(result)}
results = "ok"
else:
# results test= {"code": 500, "message": "sonar覆盖率检查未达到80%", "data": "%s"%float(result)}
results = "not ok"
else:
results = "not ok"
# print(f"Coverage metric not found in the response.")
else:
results = "not ok"
# print(f"Failed to fetch coverage. Status code: {response.status_code}")
print(results)
可以通过输出是否是ok判断,或者通过webhook api接口调用平台,都可以实现