iOS单元测试-04-覆盖率上传sonarqube
[TOC]
覆盖率报告
sonarqube需要的报告
-
随便选择一个项目,点击进去,选择
配置->设置
image
-
找到
Swift (Backelite)这个插件,这个插件及支持oc也支持swift,而且对oc语法停止了更新,对swift语法在持续更新中
image
-
分析插件中默认的报告格式
sonar-reports/coverage*.xml,需要根目录下的这个路径中的报告文件,文件名是以coverage开头,文件类型是xml的一份报告
image
XcodeCoverage工具
-
生成覆盖率文件,使用
cmd+U即可测试整个项目中的测试用例。但是这个覆盖率只能在xcode上显示,文件格式无法为我们使用,所以需要借助XcodeCoverage工具来解析结果成我们需要的报告文件
image
-
XcodeCoverage工具的使用在另一篇已经讲过了,这里不做累述
image
-
执行命令
./getcov -s,在浏览器上以html的文件格式显示覆盖率报告
image
-
在Finder中找到这个HTML文件,通过浏览器中的本地地址即可找到这个文件。可以看出来,他是被包裹在一个文件夹
lcon中,而且是以HTML的格式展示,很明显与我们想要的目标格式不太一致
image
-
执行命令
./getcov -x,执行完成之后可以发现文件夹中多了个coverage.xml的文件,很明显,这个文件就是我们上面的sonarqube报告中所需要的文件
image
-
上传
coverage.xml文件,关于sonarqube的使用另一篇文档有记录,这里不做累述。执行脚本sonar-scanner
image
-
查看覆盖率,登录sonarqube的网站,便可查看这个项目的覆盖率指标
image
image
脚本改造
-
XcodeCoverage工具生成的报告文件夹是相对于
xcodeproj文件所在的根目录文件,我们需要改造成相对于xcworkspace文件所在的根目录下的文件路径 -
getcov脚本一次只接受一个参数,如果要使用coverage.xml,操作麻烦,大致如下:- 打开xcode,使用快捷键
cmd+U来运行项目 - 打开终端,进入
XcodeCoverage文件夹,运行命令./getcov -s - 打开Finder,通过上述浏览器中的路径找到
lcov文件夹 - 切换到终端,执行命令
./getcov -x,生成coverage.xml文件 - 拷贝
coverage.xml文件到xcodeproj文件所在根目录下的sonar-reports文件夹中 - 拷贝
sonar-project.properties到根目录下 - 执行命令
sonar-scanner
- 打开xcode,使用快捷键
-
自动化脚本。上述的过程太过复杂,在真实使用的时候,需要通过自动化脚本构建,这边连带 oclint 的分析,以及单元测试的整个脚本执行都是自动化的过程。脚本暂时不考虑上传。