java插桩-Jacoco java代码覆盖率可视化

目录

工具

目录结构

使用

javaagent

何时转储

设置代理

参数

jacococli

dump命令

instrument命令

merge命令

report命令

classinfo命令

execinfo命令

version命令

使用举例(OpenDaylight)

javaagent

javacli

参考


工具

工具对比(网图,侵删)

博主使用的是jacoco-0.8.5版本

目录结构

.
├── coverage
│   ├── index.html
│   ├── jacoco.csv
│   ├── jacoco-maven-plugin
│   ├── jacoco-resources
│   ├── jacoco-sessions.html
│   ├── jacoco.xml
│   ├── org.jacoco.agent
│   ├── org.jacoco.agent.rt
│   ├── org.jacoco.ant
│   ├── org.jacoco.cli
│   ├── org.jacoco.core
│   ├── org.jacoco.examples
│   ├── org.jacoco.report
│   └── report.dtd
├── doc
│   ├── agent.html
│   ├── ant.html
│   ├── api
│   ├── api.html
│   ├── build.html
│   ├── changes.html
│   ├── check-mojo.html
│   ├── classids.html
│   ├── cli.html
│   ├── conventions.html
│   ├── counters.html
│   ├── dump-mojo.html
│   ├── empty.html
│   ├── environment.html
│   ├── epl-2.0.html
│   ├── examples
│   ├── faq.html
│   ├── flow.html
│   ├── help-mojo.html
│   ├── implementation.html
│   ├── index.html
│   ├── instrument-mojo.html
│   ├── integrations.html
│   ├── license.html
│   ├── maven.html
│   ├── merge-mojo.html
│   ├── mission.html
│   ├── offline.html
│   ├── prepare-agent-integration-mojo.html
│   ├── prepare-agent-mojo.html
│   ├── repo.html
│   ├── report-aggregate-mojo.html
│   ├── report-integration-mojo.html
│   ├── report-mojo.html
│   ├── resources
│   ├── restore-instrumented-classes-mojo.html
│   ├── support.html
│   └── team.html
├── index.html
├── lib
│   ├── jacocoagent.jar
│   ├── jacocoant.jar
│   ├── jacococli.jar
│   ├── org.jacoco.agent-0.8.5.201910111838.jar
│   ├── org.jacoco.ant-0.8.5.201910111838.jar
│   ├── org.jacoco.core-0.8.5.201910111838.jar
│   └── org.jacoco.report-0.8.5.201910111838.jar
└── test
    ├── index.html
    └── TESTS-TestSuites.xml

  •  coverage 覆盖率
  • doc 文档
  • lib 库,一些jar包  本文使用了jacocoagent.jar和jacococli.jar
  • test 测试
  • index.html 主页

使用

javaagent

何时转储

  • 文件系统:在JVM终止时,执行数据被写入本地文件。
  • TCP套接字服务器:外部工具可以连接到VM,并通过套接字连接检索执行数据。可以在JVM退出时进行可选的执行数据重置和执行数据转储。
  • TCP套接字客户端:启动时,JaCoCo代理连接到给定的TCP端点。执行数据根据请求写入套接字连接。可以在VM退出时进行可选的执行数据重置和执行数据转储。

设置代理

-javaagent:[yourpath/]jacocoagent.jar=[option1]=[value1],[option2]=[value2]

参数

选项默认值说明
destfilejacoco.exec执行数据输出文件的路径。
outputfile用于写入coverage数据的输出方法。有效选项包括:
  • file:注意,在VM终止时,执行数据将写入destfile属性中指定的文件中。
  • tcpserver:代理在address和port属性指定的TCP端口上侦听传入连接。执行数据将写入此TCP连接
  • tcpclient:在启动时,代理连接到addressport 属性指定的TCP端口。执行数据将写入此TCP连接。
  • none:不产生任何输出。
请参阅下面的安全注意事项。
address回送接口IP地址或主机名,结合output为 tcpservertcpclient。在tcpserver模式下,值“ *”使代理接受任何本地地址上的连接。
port6300当output参数为tcpservertcpclient时绑定到的端口。在 tcpserver模式下,端口必须可用,这意味着如果多个JaCoCo代理在同一台机器上运行,则必须指定不同的端口
appendtrue如果设置为true,并且执行数据文件已经存在,那么coverage数据将附加到现有文件中。如果设置为 false,将替换现有的执行数据文件。
includes* (所有类)执行分析中应包括的类名列表。列表条目用冒号(:)分隔,并且可以使用通配符(*?)。除性能优化或技术特殊情况外,通常不需要此选项
excludesempty(无排除类)应该从执行分析中排除的类名称的列表。列表条目用冒号(:)分隔,并且可以使用通配符(*?)。除性能优化或技术特殊情况外,通常不需要此选项。如果要从报告中排除类别,请相应地配置相应的报告生成工具。
exclclassloadersun.reflect.DelegatingClassLoader应该从执行分析中排除的类加载器名称的列表。列表条目用冒号(:)分隔,并且可以使用通配符(*和 ?)。在与JaCoCo代码规范冲突的特殊框架的情况下,尤其是无法访问Java运行时类的类加载器时,可能需要此选项
inclbootstrapclassesfalse指定是否还应该检测引导类加载器中的类。谨慎使用此功能,它需要大量的包含/排除调整。
inclnolocationclassesfalse指定是否还应检测没有源位置的类。通常,此类在运行时(例如,通过模拟框架)生成,因此默认情况下将其排除在外。
sessionid自动产生与执行数据一起写入的会话标识符。没有此参数,代理将创建一个随机标识符。
dumponexittrue如果设置为true,覆盖率数据将在VM关闭时写入。仅当file指定了其中一个或输出为tcpservertcpclient 并且在VM终止时打开了连接时,才能写入转储。
classdumpdir没有转储相对于工作目录的位置,代理看到的所有类文件都将转储到该目录。这对于调试目的或在动态创建类的情况下(例如在使用脚本引擎时)很有用。
jmxfalse如果设置为true,该代理由于功能原因通过JMX下的公开属性org.jacoco:type=Runtime暴露出来。请查看下面的安全注意事项。

安全注意事项:在tcpserver和 tcpclient模式下打开的端口和连接以及JMX接口不提供任何身份验证机制。如果在生产系统上运行JaCoCo,请确保没有不受信任的源可以访问TCP服务器端口,或者JaCoCo TCP客户端仅连接到受信任的目标。否则,可能会泄露应用程序的内部信息,或者可能发生DOS攻击。

jacococli

dump命令

格式

java -jar jacococli.jar dump [--address <address>] --destfile <path> [--help] [--port <port>] [--quiet] [--reset] [--retry <count>]

 向以“ tcpserver”输出模式运行的JaCoCo代理请求执行数据。

参数
选项描述
--address <address>主机名或ip,默认本机
<execfiles>要读取的JaCoCo * .exec文件列表
--classfiles <path>Java类文件的位置(必填项)
--csv <file>CSV报告的输出文件(处理数据方便)
--html <dir>HTML报告的输出目录(可视化)
--encoding <charset>源文件编码(默认情况下使用平台编码)
--help显示帮助
--name <name>此报告使用的名称
--quiet抑制stdout上的所有输出
--sourcefiles <path>源文件的位置
--tabwith <n>源页面的制表位停止宽度(默认为4)
--resetdump后重置测试目标上的执行数据
--retry <count>重试次数(默认10)

instrument命令

格式

java -jar jacococli.jar instrument [<sourcefiles> ...] --dest <dir> [--help] [--quiet]

Java类文件和JAR文件的离线检测。 

参数
选项描述
<sourcefiles>要回避检测的文件夹或文件列表
--dest <dir>将检测的Java类写入的路径
--help显示帮助
--quiet抑制stdout上的所有输出

merge命令

格式

java -jar jacococli.jar merge [<execfiles> ...] --destfile <path> [--help] [--quiet]

将多个exec文件合并到一个新的文件中。

参数
选项描述
<execfiles>要读取的JaCoCo * .exec文件列表
--destfile <path>将合并的执行数据写入的文件
--help显示帮助
--quiet抑制stdout上的所有输出

report命令

格式

java -jar jacococli.jar report [<execfiles>...] --classfiles <path> [--csv <file>] [--encoding <charset>] [--help] [--html <dir>] [--name <name>] [--quiet] [--sourcefiles <path>] [--tabwith <n>] [--xml <file>]

通过读取exec和Java类文件生成不同格式的报告。 

参数
选项描述
<execfiles>要读取的JaCoCo * .exec文件列表
--classfiles <path>Java类文件的位置(必填项)
--csv <file>CSV报告的输出文件(处理数据方便)
--html <dir>HTML报告的输出目录(可视化)
--xml <file>XML报告的输出文件
--encoding <charset>源文件编码(默认情况下使用平台编码)
--help显示帮助
--name <name>此报告使用的名称
--quiet抑制stdout上的所有输出
--sourcefiles <path>源文件的位置
--tabwith <n>源页面的制表位停止宽度(默认为4)

一般情况下填写--classfiles参数,--csv、--html、--xml中选一个,具体情况看读者要求。

classinfo命令

格式

java -jar jacococli.jar classinfo [<classlocations>...] [--help] [--quiet] [--verbose]

 在提供的位置打印有关Java类文件的信息。

参数
选项描述
<classlocations>Java类文件的位置
--help显示帮助
--quiet抑制stdout上的所有输出
--verbose显示方法和行号详细信息

execinfo命令

格式

java -jar jacococli.jar execinfo [<execfiles>...] [--help] [--quiet]

 以人类可读的格式打印exec文件内容。

version命令

格式

java -jar jacococli.jar version [--help] [--quiet]

打印JaCoCo版本信息。

参数
选项描述
--help显示帮助
--quiet抑制stdout上的所有输出

使用举例(OpenDaylight)

javaagent

java代理jar包路径: /home/llvm/apps/jacoco/lib/jacocoagent.jar

待插桩jar包路径:/usr/lib/opendaylight/karaf-0.7.3/system/org/opendaylight/openflowplugin/openflowjava/openflow-protocol-api/0.5.3/openflow-protocol-api-0.5.3.jar

1.启动时带上Javacoco的agent

sudo vim /usr/lib/opendaylight/karaf-0.7.3/bin/karaf

JAVA_OPTS="$JAVA_OPTS -javaagent:/home/llvm/apps/jacoco/lib/jacocoagent.jar=destfile=jacoco.exec,output=tcpserver"
添加JAVA_OPTS

javacli

version命令

 classinfo命令

显示类名等信息

使用一下你要测试的jar包。

dump命令

获取执行情况数据,在jacococli.jar所在目录(与jacocoagent.jar目录一致)执行命令: 

java -jar jacococli.jar dump  --port 6300 --destfile data/jacoco-it.exec

生成.exec文件

生成.exec文件

execinfo命令 

java -jar jacococli.jar execinfo data/jacoco-it.exec

 .exec中包含了包名等信息

report命令

执行如下命令生成html报告。--classfiles指定应用程序的class文件所在目录,--html指定html报告所在目录。 

java -jar jacococli.jar report data/jacoco-it.exec --classfiles /usr/lib/opendaylight/karaf-0.7.3/system/org/opendaylight/openflowplugin/openflowjava/openflow-protocol-api/0.5.3/ --html html
生成html

目录

 点击html目录中的index.html查看代码覆盖率

包的覆盖率

类、方法、分支等覆盖率
具体包中类的覆盖率

具体类中方法的覆盖率

执行以下命令,生成csv文件

java -jar jacococli.jar report data/jacoco-it.exec --classfiles /usr/lib/opendaylight/karaf-0.7.3/system/org/opendaylight/openflowplugin/openflowjava/openflow-protocol-api/0.5.3/ --csv openflow-protocol-api.csv

 只有MISSED和COVERED,需要自己计算下覆盖率。

xml及其他参数没有尝试,留给读者自行探索吧。

merge命令、instrument命令以及针对Ant、Maven框架如何使用jacoco,Eclipse、IDEA等IDE如何集成jacoco等内容也留给读者去探索吧,锻炼自己阅读官方文档的能力,学会Google、stackoverflow,加油哦!!!

参考

jacoco 官网

jacoco github

jacocoagent

jacococli

更多内容查看:网络安全-自学笔记

喜欢本文的请动动小手点个赞,收藏一下,有问题请下方评论,转载请注明出处,并附有原文链接,谢谢!如有侵权,请及时联系。如果您感觉有所收获,自愿打赏,可选择支付宝18833895206(小于),您的支持是我不断更新的动力。

  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lady_killer9

感谢您的打赏,我会加倍努力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值