像 google 一样测试系列之二:方向篇

作者:郑小辉团队:腾讯移动品质中心TMQ

一、左移方向

左移目的大家都明了,不必细说。但左移进行方向不知大家是否有想过?我觉得有2个方 向。在开发现有代码的基础点上:

向左:如何让现有代码更可测。

这里会因为人的经验,单测写法等各种原因会认为现有代码不可测。同时,输出的可测案。

例上,开发在短时间内也难以修改。新代码也不一定会按照可测性来。这个在测试程度上可能会依赖开发,如果离职换了一个新来的开发,难免又会出现这种情况。

向右:如何能测试到更多的现有代码。

这个是基于测试角度,假设开发代码就是这个样子,如何才能测试更多。这需要测试人员对单测的深度理解,对android环境,及代码实现上一个熟悉。如异步线程如何可测。

在左移上,2个方向可同时进行,这样将会达到一个最大覆盖率。

本文后续文章,都将以 向右方向进行探索和实践。

二、google单测为什么能达到70%的覆盖的理解

                         

Google单测覆盖率达到70%。然而为什么我们却达不到,甚至只能是20%。

我认为:

1、开发代码可测规范性是个原因;

2、单测的理解误区:

Google对单测的定义,也是不同于以前,可能不少人对单测的理解还停留在对一个类的测试上。google单测的定义如下图:基本上能测试的都被定义为单测了。

3、测试范围上:

国内的很多单测,大部分只做了 下图中的 1、2,很少有做 3,而4、5、6部分是基本没有。即使有也只是通过UI自动化的方式来操作的。而一般Android业务代码上,4、5占了很大比重。

以上几点是主要导致覆盖率低的原因。

三、google单测中 2种测试代码的运行机制

1、google单测之Test运行机制:

(1)Test 在google官网文档里是:Local Unit Tests。

(2)主要测试范围是: java层测试,和部分依赖Android环境的测试。

(3)Junit和Testng支持:支持Junit4和Testng,及Mock库。

(4)运行原理:

将依赖的android环境android.jar,用一个mock的android.jar替代,这个jar没有具体的实现代码,只有接口,所有的返回均可通过mock来实现你的需求。

因此是运行在JVM上的。

(5)测试代码目录:src/test/java/

(6)运行模式如下:

2、google单测 之 AndroidTest 运行机制:

(1)AndroidTest 在google官网文档里是:Instrumented Tests。这里也不要认为和之前Robotium时代的Instrumented test一样,是不一样的,这里是比之前高级一点;

(2)运行环境:运行在真机或模拟器上;

(3)主要测试范围是:理论上一切都可测,包括 Local Unit Tests;

(4)Junit和Testng支持:普通测试用例支持Junit和Testng,但Application的测试只能用Junit;

(5)运行原理:测试代码和源代码分别build成一个app,安装到真机,但是是运行在同一个进程里,因此可以调用业务代码和反射执行。测试代码运行环境均是android真环境。你可以选择mock或不mock,可以得到业务app的context等;

(6)测试代码目录:src/androidTest/java/;

(7)运行模式如下:

汇总:

问题:

你认为android测试,覆盖率可以达到多少?

UI层可以覆盖么?

组件交互层可以覆盖么?

适配可以覆盖么?

未完待续……

搜索微信公众号:腾讯移动品质中心TMQ,获取更多测试干货!

原创声明,本文系作者授权云+社区-专栏发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Python中文社区

Python=R+SQL/Hive?在数据分析与挖掘方面该选哪一个?

什么是R语言? R语言,一种自由软件编程语言与操作环境,主要用于统计分析、绘图、数据挖掘。R本来是由来自新西兰奥克兰大学的罗斯·伊哈卡和罗伯特·杰特曼开发(也因...

19510
来自专栏生信技能树

TCGA的28篇教程- 使用R语言的RTCGAToolbox包获取TCGA数据

前些天被TCGA的终结新闻刷屏,但是一直比较忙,还没来得及仔细研读,但是笔记本躺着的一些TCGA教程快发霉了,借此契机好好整理一下吧,预计28篇教程!

1533
来自专栏理论坞

一个APP的交互优化方案

这是之前为一个健身app【减约】做的交互优化建议方案,贴出来为大家分享下,有不同的建议大家也可以在留言区提出

673
来自专栏AI研习社

如何在 i5 上实现 20 倍的 Python 运行速度?

Intel Distribution for Python 在今年二月进行了更新——英特尔发布了 Update 2 版本。以“加速”为核心的它,相比原生 Pyt...

35113
来自专栏AI科技评论

开发 | 如何在 i5 上实现 20 倍的 Python 运行速度?

Intel Distribution for Python 在今年二月进行了更新——英特尔发布了 Update 2 版本。以“加速”为核心的它,相比原生 Pyt...

3796
来自专栏智能算法

Github 上 10 个最流行的数据可视化项目

1. D3 Stars: 46561, Forks: 12465 D3 是一个JavaScript数据可视化库用于HTML和SVG。它旨在将数据带入生活,强调W...

3766
来自专栏微信终端开发团队的专栏

Android微信上的SVG

资源矢量化 “清晰”和“体积”的矛盾与麻烦 面对android的各种dpi某事,想要所有设备上的图片都能有最清晰的效果,就意味着每种dpi模式都必须提供一份对应...

2725
来自专栏文智的专栏

【 文智背后的奥秘 】系列篇:结构化抽取平台

随着大数据时代的到来,一个大规模生成、分享、处理以及应用数据的时代正在开启。如果能将互联网上异源异构的非结构化或半结构化数据转换为更易处理的结构化数据,可以极大...

1.9K2
来自专栏水击三千

UML学习-活动图创建

活动图(Activity Diagram)可以实现对系统动态行为的建模,主要是将用例细化,即用例内部的细节可以以活动图的方式描述。活动图描述活动的顺序,主要表...

2195
来自专栏CSDN技术头条

Facebook开源游戏平台ELF:一个用于实时战略游戏研究的轻量级平台

ELF是一个用于游戏研究的应用广泛的(Extensive)、轻量级的(Lightweight)、灵活的(Flexible)平台,特别适用于实时战略(RTS)游戏...

2177

扫码关注云+社区