从精准化测试看ASM在Android中的强势插入-JaCoco初探,我浪费了自己职业生涯的黄金5年

从官网上就能看出这是一个极具历史感的项目。最后生成的覆盖率文件,是在 源代码的基础上,用颜色标记不同的执行状态。

在上面这张图中,绿色代表已执行, 红色代表未执行, 黄色代表执行了一部分,这样就可以算出代码的覆盖率数据。

使用全量报表


JaCoco默认的插桩方式是全部插桩,在Android项目中,要使用JaCoco的全量报表功能非常简单,因为JaCoco插件已经集成在Gradle中了,所以我们只需要开启JaCoco即可。

首先,在根目录gradle文件中加入JaCoco的依赖

classpath "org.jacoco:org.jacoco.core:0.8.4"

然后在App的gradle文件中增加插件的依赖。

apply plugin: ‘jacoco’

并在android标签中,增加开关。

testCoverageEnabled = true

接下来引入JaCoco的Report模块,同时exclude掉core,因为其在gradle中已经有依赖了。

implementation(‘org.jacoco:org.jacoco.report:0.8.4’) {

exclude group: ‘org.jacoco’, module: ‘org.jacoco.core’

}

创建生成Report的Task

def coverageSourceDirs = [‘…/xxxx/src/main/java’]

task jacocoTestReport(type: JacocoReport) {

group = “Reporting”

description = “Generate Jacoco coverage reports after running tests.”

reports {

xml.enabled = true

html.enabled = true

}

classDirectories.setFrom(fileTree(

dir: ‘./build/intermediates/javac/xxxxx’,

excludes: [‘**/R*.class’]))

sourceDirectories.setFrom(files(coverageSourceDirs))

executionData.setFrom(files(“$buildDir/outputs/code-coverage/connected/coverage.exec”))

doFirst {new File(“$buildDir/intermediates/javac/masterDebug/classes/com/qidian/QDReader”).eachFileRecurse { file ->

if (file.name.contains(‘$$’)) {

file.renameTo(file.path.replace(‘$ ′ , ′ ', ' ,’))

}

}

}

}

在项目中合适的地方来调用这两个方法,分别用来创建JaCoco的Exec文件和写入Exec文件。

private void createExecFile() {

String DEFAULT_COVERAGE_FILE_PATH = “/mnt/sdcard/” + getPackageName();

String DEFAULT_COVERAGE_FILE = DEFAULT_COVERAGE_FILE_PATH + “/coverage.ec”;

File file_path = new File(DEFAULT_COVERAGE_FILE_PATH);

File file = new File(DEFAULT_COVERAGE_FILE);

Log.d(TAG, "file_path = " + file_path);

if (!file.exists()) {

try {

file_path.mkdirs();

file.createNewFile();

} catch (IOException e) {

e.printStackTrace();

}

}

}

private void writeExecFile() {

OutputStream out = null;

try {

out = new FileOutputStream(“/mnt/sdcard/” + getPackageName() + “/coverage.ec”, true);

Object agent = Class.forName(“org.jacoco.agent.rt.RT”)

.getMethod(“getAgent”)

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数软件测试工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年软件测试全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上软件测试开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注软件测试)
img

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注软件测试)
[外链图片转存中…(img-3jswZ073-1712742341717)]

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值