jacoco的多次代码提交merge分析

2024-04-27 16:18

本文主要是介绍jacoco的多次代码提交merge分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

jacoco的merge命令主要用来合并dump生成的exec文件,具体实施场景为分布式集群环境时由于覆盖请求负载到不同的机器上产生多个exec文件后我们再做merge操作,从而获取到代码的整体覆盖率,具体操作如下图所示:

命令如下:

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

示例:

java -jar jacococli.jar merge 1.exec 2.exec --destfile /var/merged.exec

https://www.jacoco.org/jacoco/trunk/doc/cli.html

但是官方明确了,只有相同代码生成的exec文件才能做merge操作,那么如下场景我们需要怎么做呢?

这里先插一句:其实jacoco的report命令本身支持传入多个exec文件,他会将其进行合并,所以可以省略merge这个步骤

比如说:

项目发测了,第一轮测试dump生成了exec文件

后面又进行了两轮测试,从而生成了三份exec文件,而我想查看本次整体测试的代码覆盖率怎么办呢,jacoco官方不知道这样搞,那我们只能自己搞搞了,我们需要找出为啥不能合并,一层层剥开它的壳

1.下载jacoco官网源码,找到merge的测试类,加一个测试方法,简单指定了合并后文件目录,需要合并的exec文件目录

2.debug模式运行,前面解析命令的可以不用看,我们直接看核心方法

解析完命令后,这里加载我们需要合并的exec文件,大体逻辑器,先加载一个文件解析文件里面的类id,类名和探针,存放在一个map里面,然后将后面的类和探针进行合并,最终生成合并后的数据集合

这里是逐个类进行解析,这里获取到了类的id,类的全限定名和类里面的探针,核心逻辑就在这里了

我们看看最后合并操作

合并前会classid,类全限定名以及探针数量的对比,其中一项失败就会导致整个类合并失败,看到这里想必大家有所了解了

那么classId是什么呢?classid讲解  Currently ids are created with a CRC64 checksum of the raw class file,我们修改类里面的代码这个id肯定是不同的

如果我们去掉这个id的对比,如果类发生了变化,探针对应的顺序就会错乱,导致A方法的探针跑到B方法

盗图可耻图片来源如果有侵权请大佬联系我删除

所以这种方案是行不通的,是否有新的方案,我再思考下。



分割

最近和群里的小伙伴们讨论了很多方案,有些小伙伴们按照了自己的想法也实现了多个代码版本合并。这里我整理下我最近的一些想法。

首选我们如果要合并覆盖率就不能以原生的方式去合并class id。我们需要修改源码,按照类名去做合并,同时我们需要把原来的覆盖率转换为方法的覆盖行。我们肯定不能用新的类无脑覆盖旧的类,这样准确率就相差比较大了,我们看下面具体的思路

 

 上图所示,我们假设有四个类,我们的变动都是在第一次变动后的第二次变动,interface可以理解成一个接口,使我们一个业务逻辑的起始方法,我们按照变动的范围逐一分析。

  • 假设变动的是interface1,因为interface1的变动我们要重新覆盖,我们在覆盖interface1的时候可能对其所调用的方法methodA等做了其他分支的覆盖,所以现在的策略应该是,interface1使用新的覆盖,interface1所调用的方法合并两次的覆盖
  • 假设我们变动的methodA,显然我们的methodA需要使用新的覆盖,旧的覆盖作废,而其调用的方法需要合并两次的覆盖,而调用其的方法interface1同样需要合并两次的覆盖
  • 假设我们变动的是methodC,则其覆盖使用新的数据,所有调用其的调用链所涉及的方法,都需要合并两次的覆盖,
  • 假设我们变动的是methodB,这里的策略依旧是methodB使用新的,其调用和被其调用的方法链上的覆盖都都需要合并两次的,这里有一个涉及点,因为methodB的变动,可能会影响methodC的变动情况,或者说methodA的重新覆盖,也会影响其所有调用方法的覆盖情况,所以这里的methodC我们也需要做两次覆盖的情况

整体流程大体如上所述,我们需要考虑方法的变动而引起的覆盖变化,合并的时候部分直接使用旧的覆盖,部分使用新的覆盖,部分合并两次的覆盖,我们要明确好具体的合并策略。

无论是否使用上述方案合并,我们最基础的都是需要拿到方法的调用链,调用链又分为静态调用链和动态调用链,动态调用链更准确,但是不合适我们这边的使用场景,我们需要使用静态代码分析出变更方法的调用链

总结下:合并代码多次变更覆盖的方案

  1. 修改jacoco的merge源码,将覆盖的行转换成方法覆盖的行,修改原本按照classId合并的方案,按照类名去合并
  2. 分析变更代码的调用链,确定其影响范围,明确方法的覆盖策略(code-diff已经支持分析静态调用链的源码可以参考)

以上就是针对多次提交代码覆盖率合并的设想,可能存在问题,欢迎大家一起讨论。

这篇关于jacoco的多次代码提交merge分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/940961

相关文章

Java进行日期解析与格式化的实现代码

《Java进行日期解析与格式化的实现代码》使用Java搭配ApacheCommonsLang3和Natty库,可以实现灵活高效的日期解析与格式化,本文将通过相关示例为大家讲讲具体的实践操作,需要的可以... 目录一、背景二、依赖介绍1. Apache Commons Lang32. Natty三、核心实现代

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

SpringBoot实现二维码生成的详细步骤与完整代码

《SpringBoot实现二维码生成的详细步骤与完整代码》如今,二维码的应用场景非常广泛,从支付到信息分享,二维码都扮演着重要角色,SpringBoot是一个非常流行的Java基于Spring框架的微... 目录一、环境搭建二、创建 Spring Boot 项目三、引入二维码生成依赖四、编写二维码生成代码五

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序

MySQL中的两阶段提交详解(2PC)

《MySQL中的两阶段提交详解(2PC)》:本文主要介绍MySQL中的两阶段提交(2PC),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录引言两阶段提交过程sync_binlog配置innodb_flush_log_at_trx_commit配置总结引言在Inn

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见