Android 代码覆盖率统计

本周开始准备统计Android自动化用例的代码覆盖率,将最终使用的方法记录下来。

覆盖率监测的原理

覆盖率监测的原理跟iOS上的原理差不多,大致的思路参考下吧,

iOS自动化探索(十)代码覆盖率统计

Android使用的是JaCoCO覆盖率统计工具  jacoco 原理篇

必要知识储备或条件:

  • 项目源码
  • Android Studio开发环境
  • 基本了解Android项目结构
  • 基础adb操作

同样如果以上说的几个都不懂也行, 让开发帮忙做这些然后编个代码覆盖率统计的包给你测试, 测完把手机给开发取数据生成报告。 注意每次测试完先返回手机桌面把程序退到后台等几秒让app自己生成日志文件

下面开始讲步骤

步骤1:拉取项目代码

git clone XXXXXXXXXXX

步骤2:使用Android Studio打开项目

步骤3:配置build.gradle

apply plugin: 'com.android.application'
apply plugin: 'jacoco' //加载代码覆盖库jacoco jacoco {
toolVersion = "0.7.9" //代码覆盖库jacoco版本号
} android {
compileSdkVersion
buildToolsVersion "25.0.3"
defaultConfig {
applicationId "com.whh.initmvp"
minSdkVersion
targetSdkVersion
versionCode
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
testCoverageEnabled = true //实现代码覆盖率
minifyEnabled false //获取代码覆盖率需要设为false (**如果混肴文件配置完毕,设为true也可**)
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
debug {
testCoverageEnabled = true //实现代码覆盖率
minifyEnabled false //获取代码覆盖率需要设为false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
} dependencies {
compile fileTree(include: ['*.jar'], dir: 'libs')
testCompile 'junit:junit:4.12' //.....(此处忽略若干依赖库) //代码覆盖率jacoco(可不引入)
// compile 'org.jacoco:org.jacoco.core:0.7.9' } //代码覆盖率相关配置 start
def coverageSourceDirs = [
'../app/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 = fileTree(
//检测覆盖率的class所在目录(以项目class所在目录为准)
dir: './build/intermediates/classes/debug', //gradle2.3 class所在目录
//gradle3.2 class所在目录 dir: './build/intermediates/javac/debug/compileDebugJavaWithJavac/classes',
//增加以上目录中不需要检测的文件列表
excludes: ['**/R*.class',
'**/*$InjectAdapter.class',
'**/*$ModuleAdapter.class',
'**/*$ViewInjector*.class'
]
) sourceDirectories = files(coverageSourceDirs) //设置需要检测覆盖率的目录
executionData = files("$buildDir/outputs/code-coverage/connected/code_coverage.ec") //存储APP运行时产生报告的路径
}
//代码覆盖率相关配置 end

注意事项:

  • compile 'org.jacoco:org.jacoco.core:0.7.9' 库包可不添加依赖;
  • classDirectories的设置应以项目编译后生成的class文件目录为准,比如:gradle2.3 class所在目录:dir: './build/intermediates/classes/debug',  gradle3.2 class所在目录: dir: './build/intermediates/javac/debug/compileDebugJavaWithJavac/classes'
  • executionData的设置,自定义生成的报告的路径及报告名称,既然设定,在指定目录下需要有这样的文件,文件夹及文件名称都要一一对应,不可粗心输错;
  • 注意以上注释的位置,每一个配置务必加上以保证检测代码覆盖率的实现;

步骤4:确认APP有开启文件读写权限

在AndroidManifest.xml中添加

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

步骤5:在项目的BaseActivity Class中添加以下代码:

这里不一定都叫BaseActivity文件, 具体要找到自己项目的底层Activity在里面添加

//生成报告的所在SDcard目录
public static String DEFAULT_COVERAGE_FILE_PATH = Environment.getExternalStorageDirectory()+"/";
private static final String TAG = "MainActivity"; @Override
protected void onStop() {
generateCoverageFile();
super.onStop(); } /**
* 生成executionData
*/
public void generateCoverageFile() { OutputStream out = null; try {
out = new FileOutputStream(DEFAULT_COVERAGE_FILE_PATH + "/code_coverage.ec", false); //在SDcard根目录下生产检测报告,文件名自定义
Object agent = Class.forName("org.jacoco.agent.rt.RT").getMethod("getAgent").invoke(null);
// 这里之下就统计不到了
out.write((byte[]) agent.getClass().getMethod("getExecutionData", boolean.class).invoke(agent, false)); Log.i("whh", "GenerateCoverageFile success");
} catch (Exception e) {
Log.i("whh", "GenerateCoverageFile Exception:" + e.toString()); } finally {
if (out != null) {
try {
out.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}

步骤6:同步Gradle

点击Sync Now, 完成后找到Gradle窗口

步骤7:安装APP到手机

连接上手机后, 点击上面的installDebug. (注意: 这里不同的项目可能install目录下的名称不一样, 选择自己需要的安装脚本)

步骤8:运行自动化测试用例或手工用例

注意没运行完一个case需要把手机返回桌面等几秒,不要杀掉APP进程

并在手机文件根目录下找到code_coverage.ec文件, 这个就是覆盖率数据

如果没有的话重新打开一次APP试试, 还是没有的话检查下上面的步骤是不是哪里漏掉了

步骤9:获取覆盖率数据

adb pull /sdcard/code_coverage.ec

步骤10: 拷贝覆盖率数据

把上面获取到的覆盖率数据复制到项目的app/build/outputs/code-coverage/connected/目录下,如果没有该目录,可手动创建

注意这里的路径要跟上面build.gradle里面写的一致

executionData = files("$buildDir/outputs/code-coverage/connected/code_coverage.ec")

步骤11:生成覆盖率报告

点击Gradle窗口中的jacocoTestReport即可

报告一般在app\build\reports目录

打开里面的index.html就是我们要的报告了

我的博客即将同步至腾讯云+社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=2crdqmdtflogs

Android自动化测试探索(五)代码覆盖率统计的更多相关文章

  1. Android自动化测试探索

    Android自动化测试探索 前言 通常来说,我们开发完成产品之后,都是由测试组或者是我们自己点一点,基本上没有问题了就开始上线.但是,随着时间的堆叠,一款产品的功能也越来越多.这时,我们为了保证产品 ...

  2. Android自动化测试探索(七)代码覆盖率统计

    之前在 https://www.cnblogs.com/zhouxihi/p/11453738.html 这篇写了一种统计Android覆盖率的方式 但是对于一些比较复杂或者代码结构不够规范的项目,有 ...

  3. Android自动化测试探索(二)常用自动化工具

    Android常用自动化工具 ADB - 是Google提供的为Android编写UI测试用例的自动化工具, Android开发/测试人员不可替代的强大工具 uiautomator - 是Google ...

  4. Android自动化测试探索(三)Android SDK tools安装、aapt配置以及使用aapt获取apk包名

    Android SDK tools安装 下载连接: https://www.androiddevtools.cn 找到对应mac的版本下载安装即可 AAPT配置 #1. 进入根目录 cd ~ #2. ...

  5. Android自动化测试探索(四)uiautomator2简介和使用

    uiautomator2简介 项目Git地址: https://github.com/openatx/uiautomator2 安装 #1. 安装 uiautomator2 使用pip进行安装, 注意 ...

  6. Android自动化测试探索(一)adb详细介绍

    adb详细介绍 #1. 基本简介 adb,即Android Debug Bridge,它是Android开发/测试人员不可替代的强大工具 #2. Mac上安装adb 安装brew /usr/bin/r ...

  7. iOS自动化探索(十)代码覆盖率统计

    iOS APP代码覆盖率统计 今年Q3季度领导给加了个任务要做前后端代码覆盖率统计, 鉴于对iOS代码代码比较熟就选择先从iOS端入手,折腾一整天后终于初步把流程跑通了记录如下 覆盖率监测的原理 Xc ...

  8. 【Mac + Appium + Python3.6学习(五)】之常用的Android自动化测试API总结

    Github测试样例地址:https://github.com/appium-boneyard/sample-code/tree/master/sample-code/examples ①定位text ...

  9. Android自动化测试基础知识——MONKEY测试工具(转的)

    本周开始启动手机输入法simeiji的自动化测试,同时开始接触手机浏览器自动化测试.接下来会对android自动化测试工具和方法做一个专题研究. 第一篇介绍monkey测试工具. 1 自动化测试背景 ...

随机推荐

  1. Unity3D热更新之LuaFramework篇[08]--热更新原理及热更服务器搭建

    前言 前面铺垫了这么久,终于要开始写热更新了. Unity游戏热更新包含两个方面,一个是资源的更新,一个是脚本的更新. 资源更新是Unity本来就支持的,在各大平台也都能用.而脚本的热更新在iOS平台 ...

  2. Spark 源码分析系列

    如下,是 spark 源码分析系列的一些文章汇总,持续更新中...... Spark RPC spark 源码分析之五--Spark RPC剖析之创建NettyRpcEnv spark 源码分析之六- ...

  3. thinkphp 多对多表查询

    1.表 班级表classes 学生表student 中间表classes_students 2.使用模型关联查询 新建模型 Classes在里面添加代码 ClassesStudent中间表模型,可以不 ...

  4. 前端js性能优化的要点

    1 尽量少使用全局查找,比如全局变量,如果要多次使用,可以将全局变量存为局部变量再使用 eg:function(){ var body=document.body; alert(body): body ...

  5. python redis连接 有序集合去重

    # -*- coding: utf-8 -*- import redisfrom constant import redis_ip, redis_db, redis_pw, logger, redis ...

  6. Thread.Sleep太久,界面卡死

    在Winform程序的UI界面使用Thread.Sleep,窗体界面会被卡死,如图1所示,程序sleep 5000毫秒,时间到了之后,按钮的名称才更改过来,窗体也能被鼠标拖动.而用Delay方法,就能 ...

  7. S2:java集合框架

    Java集合就是一个容器.面向对象语言对事物的体现都是以对象的形式存在,所以为了方便对多个对象的操作,就对对象进行存储,集合就是存储对象最常用的一种方式.集合只用于存储对象,集合长度是可变的,集合可以 ...

  8. LR(1)语法分析器生成器(生成Action表和Goto表)java实现(一)

    序言 : 在看过<自己实现编译器链接器>源码之后,最近在看<编译器设计>,但感觉伪代码还是有点太浮空.没有掌握的感觉,也因为内网几乎没有LR(1)语法分析器生成器的内容,于是我 ...

  9. Netty学习(二)-Helloworld Netty

    这一节我们来讲解Netty,使用Netty之前我们先了解一下Netty能做什么,无为而学,岂不是白费力气! 1.使用Netty能够做什么 开发异步.非阻塞的TCP网络应用程序: 开发异步.非阻塞的UD ...

  10. azure k8s netcore 程序初次部署

    以下都是我在2018年12月份做的实验,今天才发布出来. 念想 首先是了解一些关于K8s的一些基础概念,推荐查看一下这个链接,非常适合入门k8s.是因为K8S的环境搭建比较复杂(最主要是懒),其实也有 ...