Fork me on GitHub

一次排查$jacocoData的过程

起因

最近在开发过程中,遇到了一个奇怪的现象,在测试环境去利用反射拿一个类的字段时,发现拿到的field数组中多了一个奇怪的变量:$jacocoData,是一个static的boolean数组:

很明显jacoco这种统计代码覆盖率不是我定义在一个业务含义的类中,这时考虑到可能是测试环境中对代码覆盖率在编译时对字节码进行了修改,于是去测试环境的机器上看这个jar包。

疑惑点

在机器上对jar包解压(解压命令jar -xvf xxxxxxx.jar),并且在对应的目录下找到对应的calss文件,注意这里解压之后的要看的字节码文件都在BOOT-INF目录的lib下:

将反编译的字节码复制了下来,却发现对应的字节码中并没有这个变量。

这里就不是网上说的很多编译时修改字节码来实现测试覆盖率的功能。

解决

后来问了部署jacoco服务的框架组人员,发现是用了java Agent在修改运行时字节码实现的,拉了dump发现确实在运行时进行字节码修改的,而在jacoco官方的github也曾经有过这个问题的issue:

jacocoData

关于java Agent技术可以参考博客:agent博客,这里提到了asm技术和agent探针参数。

所以在反射取字段时候遇到这个坑比较难排查,记录一下。这里的解决办法参考了博客:$jacocoData问题的解决,即使用了是否为复合字段的field方法解决。

-------------本文结束感谢您的阅读-------------

本文标题:一次排查$jacocoData的过程

文章作者:夸克

发布时间:2019年03月10日 - 21:03

最后更新:2022年07月01日 - 05:07

原始链接:https://zhanglijun1217.github.io/2019/03/10/一次排查-jacocoData的过程/

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。