集成测试尝试jacoco统计测试覆盖率

一、背景

1、项目紧加快迭代,部分同学出现不适应发版节奏的情况,漏测造成出现线上bug。

二、期望

1、借助jacoco提高用例的代码覆盖率

2、熟悉jacoco,逐渐良好地运用到项目中,成为增强产品质量的一环

三、选型

1、基于On-The-Fly模式无侵入、系统不需要停机、实时手机代码覆盖率的优点,选择采用On-The-Fly模式

四、实现

1、将下载的jacoco.zip与tomcat放在同一台机器上

2、在/tomcat/bin/catalina.sh中添加JAVA_OPTS="$JAVA_OPTS -javaagent:{存放jacocoagent.jar的路径}/jacocoagent.jar=includes=*,output=tcpserver,address=127.0.0.1,port=4399 -Xverify:none"

3、重启tomcat,ps -ef|grep tomcat 查看是否带有-javaagent参数

4、使用yum安装ant

5、编辑ant使用的build.xml文件

<?xml version="1.0" encoding="UTF-8"?> <project name="Jacoco" xmlns:jacoco="antlib:org.jacoco.ant" default="jacoco"> <!--Jacoco 的安装路径--> <property name="jacocoantPath" value="[yourPath/]jacocoant.jar"/> <!--最终生成 .exec 文件的路径,Jacoco 就是根据这个文件生成最终的报告的--> <property name="jacocoexecPath" value="[yourPath/]jacoco.exec"/> <!--生成覆盖率报告的路径--> <property name="reportfolderPath" value="[storageReportPath]"/> <!--远程 Tomcat 服务的 ip 地址--> <property name="server_ip" value="100.44.44.144"/> <!--前面配置的远程 Tomcat 服务打开的端口,要跟上面配置的一样--> <property name="server_port" value="8044"/> <!--源代码路径--> <property name="checkOrderSrcPath" value="[srcPath]" /> <!--.class 文件路径--> <property name="checkOrderClasspath" value="[classPath]" /> <!--让 ant 知道去哪儿找 Jacoco--> <taskdef uri="antlib:org.jacoco.ant" resource="org/jacoco/ant/antlib.xml"> <classpath path="${jacocoantPath}" /> </taskdef> <!--dump 任务: 根据前面配置的 ip 地址,和端口号, 访问目标 Tomcat 服务,并生成 .exec 文件。--> <target name="dump"> <jacoco:dump address="${server_ip}" reset="false" destfile="${jacocoexecPath}" port="${server_port}" append="true"/> </target> <!--jacoco 任务: 根据前面配置的源代码路径和 .class 文件路径, 根据 dump 后,生成的 .exec 文件,生成最终的 html 覆盖率报告。--> <target name="report"> <delete dir="${reportfolderPath}" /> <mkdir dir="${reportfolderPath}" /> <jacoco:report> <executiondata> <file file="${jacocoexecPath}" /> </executiondata> <structure name="JaCoCo Report"> <group name="Check Order related"> <classfiles> <fileset dir="${checkOrderClasspath}"> <!-- 过滤不必要的文件 --> <exclude name="**/R.class"/> <exclude name="**/R$*.class"/> <exclude name="**/*$ViewInjector*.*"/> <exclude name="**/BuildConfig.*"/> <exclude name="**/Manifest*.*"/> </fileset> </classfiles> <sourcefiles encoding="UTF-8"> <fileset dir="${checkOrderSrcPath}" /> </sourcefiles> </group> </structure> <html destdir="${reportfolderPath}" encoding="UTF-8" /> <csv destfile="${reportfolderPath}/coverage-report.csv" encoding="UTF-8"/> <xml destfile="${reportfolderPath}/coverage-report.xml" encoding="UTF-8"/> </jacoco:report> </target> </project>
6、ant dump
7、ant report
五、报告怎么读

Jacoco从多种角度对代码进行了分析,包括指令(Instructions,C0 Coverage),分支(Branches,C1 Coverage),圈复杂度(Cyclomatic Complexity),行(Lines),方法(Methods),类(Classes)。

1. Instructions
Jacoco计算的最小单位就是字节码指令。指令覆盖率表明了在所有的指令中,哪些被指令过以及哪些没有被执行。这项指数完全独立于源码格式并且在任何情况下有效,不需要类文件的调试信息。

2. Branches
Jacoco对所有的if和switch指令计算了分支覆盖率。这项指标会统计所有的分支数量,并同时支出哪些分支被执行,哪些分支没有被执行。这项指标也在任何情况都有效。异常处理不考虑在分支范围内。
在有调试信息的情况下,分支点可以被映射到源码中的每一行,并且被高亮表示。

红色钻石:无覆盖,没有分支被执行。
黄色钻石:部分覆盖,部分分支被执行。
绿色钻石:全覆盖,所有分支被执行。

3. Cyclomatic Complexity
Jacoco为每个非抽象方法计算圈复杂度,并也会计算每个类,包,组的复杂度。根据McCabe1996的定义,圈复杂度可以理解为覆盖所有的可能情况最少使用的测试用例数。这项参数也在任何情况下有效。

4. Lines
该项指数在有调试信息的情况下计算。因为每一行代码可能会产生若干条字节码指令,所以我们用三种不同状态表示行覆盖率

红色背景:无覆盖,该行的所有指令均无执行。
黄色背景:部分覆盖,该行部分指令被执行。
绿色背景:全覆盖,该行所有指令被执行。

5. Methods
每一个非抽象方法都至少有一条指令。若一个方法至少被执行了一条指令,就认为它被执行过。因为JaCoco直接对字节码进行操作,所以有些方法没有在源码显示(比如某些构造方法和由编译器自动生成的方法)也会被计入在内。

6. Classes
每个类中只要有一个方法被执行,这个类就被认定为被执行。同5一样,有些没有在源码声明的方法被执行,也认定该类被执行。

7、点击Element,可查看未覆盖的代码行

六、应用

1、根据报告中未覆盖的代码,进行用例的补充

posted on 2019-07-24 14:35  九吴凡  阅读(462)  评论(0编辑  收藏  举报

导航