前言:最近工作需要将特别多的存储过程,转到Java程序中实现(JDBC连接数据库,存储过程方法的sql逻辑提取为Java代码逻辑实现),因涉及代码逻辑分支特别多,为保证代码逻辑能确保执行(怕某业务场景的分支代码块没有执行过,而开发人员无法确认代码是否存在一些bug)。
在此引用Jacoco用于代码覆盖率测试。

下载Jacoco

EclEmma - JaCoCo Java Code Coverage Library

java 代码测试覆盖率 java跑覆盖率_java 代码测试覆盖率

选择一个最新的下载,解压压缩包后如下,里面有一些例子、文档等: 

java 代码测试覆盖率 java跑覆盖率_java_02

进入lib目录,里面的几个jar就是使用的工具

java 代码测试覆盖率 java跑覆盖率_jar_03

可以在当前目录新建bat程序

导出.bat

 java -jar jacococli.jar dump --address localhost --destfile dump/test.exec

 合并.bat

 java -jar jacococli.jar merge dump/*.exec --destfile merge/all.exec

 生成测试报表.bat

java -jar jacococli.jar report ./merge/all.exec --classfiles D:\Work\work_2020_03\IPMP2.0-临时提交区-050.编码\010.公共\010.源代码\JAVA\EIpmp2ProcAdapter\target\classes --sourcefiles D:\Work\work_2020_03\IPMP2.0-临时提交区-050.编码\010.公共\010.源代码\JAVA\EIpmp2ProcAdapter\src --encoding utf-8 --html jacoReport

在命令控制台输入命令,可以查看生成报表的几个参数定义如下 

java 代码测试覆盖率 java跑覆盖率_开发语言_04

 准备好后如下:

java 代码测试覆盖率 java跑覆盖率_jar_05

 java应用程序启动时候需配置参数

"-javaagent:%javacoco的目录%/jacoco-0.8.8/lib/jacocoagent.jar=output=tcpserver,port=6300,address=localhost,includes=com.shine.ipmp2.proc.**"

includes = 需要监控的java代码包

然后启动java应用程序,调用相关的服务,依次执行导出.bat、合并.bat、生成测试报表.bat

结果如下:

java 代码测试覆盖率 java跑覆盖率_java 代码测试覆盖率_06

进入jacoReport目录可以查看相关的代码覆盖率结果

java 代码测试覆盖率 java跑覆盖率_jar_07

可以看见很多类的覆盖执行结果 

java 代码测试覆盖率 java跑覆盖率_java_08

 

点击打开某个类,可以看见执行结果,绿色是执行过,红色是没有执行,黄色是部分执行

java 代码测试覆盖率 java跑覆盖率_开发语言_09

 

到这里就掌握了Jacoco的入门使用了,相信有人会很好奇这个东西是如何实现覆盖率监控实现的。

我猜测下这东西的底层实现原理吧。

"-javaagent:jacoco-0.8.8/lib/jacocoagent.jar=output=tcpserver,port=6300,address=localhost,includes=com.shine.ipmp2.proc.**"

从启动应用程序发现使用了javaagent,里面有好几个参数,监听了端口开启了tcp服务,配置了需要扫描监控的包名。

可以猜测应该是使用javaagent拦截classload加载class时候,使用ASM字节码技术,去分析需要拦截package下的每个class文件,存在逻辑分支代码块的地方就新增字节码,使用一个对象(存在boolean值)记录每个类方法逻辑分支处的信息,如果有执行过那么修改为true,在使用导出命令时候,该程序会连接java应用程序的端口下载前面标红的对象信息。然后有了信息就能合并且生成报表了。