前言:最近工作需要将特别多的存储过程,转到Java程序中实现(JDBC连接数据库,存储过程方法的sql逻辑提取为Java代码逻辑实现),因涉及代码逻辑分支特别多,为保证代码逻辑能确保执行(怕某业务场景的分支代码块没有执行过,而开发人员无法确认代码是否存在一些bug)。
在此引用Jacoco用于代码覆盖率测试。
下载Jacoco
EclEmma - JaCoCo Java Code Coverage Library
选择一个最新的下载,解压压缩包后如下,里面有一些例子、文档等:
进入lib目录,里面的几个jar就是使用的工具
可以在当前目录新建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应用程序启动时候需配置参数
"-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
结果如下:
进入jacoReport目录可以查看相关的代码覆盖率结果
可以看见很多类的覆盖执行结果
点击打开某个类,可以看见执行结果,绿色是执行过,红色是没有执行,黄色是部分执行
到这里就掌握了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应用程序的端口下载前面标红的对象信息。然后有了信息就能合并且生成报表了。