像 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 条评论
登录 后参与评论

相关文章

来自专栏Alan's Lab

使用 gzip 以及 cdn 加快前端载入速度

还记得在 Angular 2 Component 中使用第三方 JS 库这篇文章里说有个新项目用了 Angular2 么?这篇文章还是跟这个项目有关,为了减少每...

2232
来自专栏数据和云

经典文档:Oracle Database 12.2新特性概览解读下载

在2017 OOW大会上,关于Oracle Database 12.2 数据库的新特性介绍仍然引人瞩目,会后公布了 Oracle VP Swonger的文档,我...

3037
来自专栏IT派

10 个技巧,让你更专业地使用 console 进行 JS 调试

首先,我必须承认这一点,我将利用这个平台从我的开发环境中清理出骨架(轮廓)。有时候,我所做的“魔法”(有些人称之为“编码”),并不像我的同事在为他们展示这些宏伟...

890
来自专栏AhDung

【工具】清理Windows Installer冗余文件(支持64位NT6.x系统)

Windows NT 5.x/6.x 32及64位所有系统。需.net framework 2.0运行环境

1272
来自专栏野路子程序员

徒手解剖composer,简单了解其实现过程

2786
来自专栏老九学堂

编程必备武器,你玩过几种?

古人说工欲善其事 必先利其器,对于咱们程序员也一样,一个好的工具可以节约很多时间和精力,而一个标准的程序员在工作中要接触到的编程工具实在太多,那么对于新手,该如...

3594
来自专栏编程

2018 年初值得关注的 25 个新 Android 库和项目

协作翻译 原文:25 new Android libraries and projects to check at the beginning of 2018 ...

23310
来自专栏腾讯大讲堂的专栏

Android开发在路上:少去踩坑,多走捷径

最近一朋友提了几个Android问题让我帮忙写个小分享,我觉得对新人还是挺有帮助的,所以有了这个小分享。 1.目前, Android APP开发完成后,通常需要...

20710
来自专栏Java架构

JAVA程序员怎么样才能进一线互联网公司

2.做过哪些项目?项目中遇到哪些难点,你是怎样解决的?单点登录系统说一下?分布式缓存的使用场景?(说好的基础呢,上来就是项目,毫无准备,导致好多东西都记不起来了...

1212
来自专栏张伟博客

多合一收款二维码合并原理及源码-支持支付宝、微信、QQ

最近去超市看到好多商户一个二维码同时支持支付宝、微信、QQ扫描付款,所以回来自己上网研究了一下。整理了一个现成的源码,有需要的朋友可以下载自己研究下。

2134

扫码关注云+社区