Skip to content

Latest commit

 

History

History
210 lines (141 loc) · 10.9 KB

19 android产品研发-AS单元测试.md

File metadata and controls

210 lines (141 loc) · 10.9 KB

上一篇文章中我们讲解了webview中问题集锦,讲解了webview的性能优化,讲解了webview种入Cookie信息,讲解了activity退出的时候清除webview信息报错,讲解了如何通过java代码和js代码相互交互,讲解了webview如何下载文件以及腾讯的X5浏览服务等知识,这些都是我在使用webview中遇到的问题,难点,实践等,更多关于这些问题的说明,可以参考我的:android产品研发(十八)-->webview趟过的坑

这篇文章中我们将讲解如何在android studio中进行单元测试。在android开发项目中,经常会测试,而一次又一次的运行模拟器,不但慢,会需要大量时间,还会工作效率降低,重复做一些无用的操作,虽然最新的android studio中提供了instance run功能,来提高android studio的编译速度,但是我们还是需要了解android studio的单元测试功能,其可以很方便的为我们提供功能性测试,所以如果项目中有用到测试数据的时候,可以先进行单元测试,如果可以正常输出数据了,然后再到UI中执行,这样会提高一些工作效率。

什么是单元测试:

在讲解如何在android studio中进行单元测试之前我们先普及一下基本知识,即什么是单元测试,这里我先引用一下百科中对单元测试的描述:

是指对软件中的最小可测试单元进行检查和验证。对于单元测试中单元的含义,一般来说,要根据实际情况去判定其具体含义,如C语言中单元指一个函数,Java里单元指一个类,图形化的软件中可以指一个窗口或一个菜单等。总的来说,单元就是人为规定的最小的被测功能模块。单元测试是在软件开发过程中要进行的最低级别的测试活动,软件的独立单元将在与程序的其他部分相隔离的情况下进行测试。

简单来说单元测试就是将一个软件功能拆分成N个最小的不可拆分的单元功能点,对着单元功能点的测试就是单元测试。

单元测试有什么作用:

android中的测试一般分为:功能测试,ui测试,单元测试等等; 由于app运行需要android运行环境,而我们的android的单元测试一般无法提供运行环境,所以一般像功能测试,UI测试等都需要在模拟器或者是真机上进行,但是一些功能性的需求不需要android环境的功能,如果也使用android studio重新编译运行,那么耗费的时间就太长了,一般来说一个apk文件编译,安装,运行的时间一两分钟都是普遍的,三四分钟也可能,这样为了测试一个简单的功能,就需要花费这么长的时间重新编译运行,性价比太低。

因此单元测试主要是功能测试,主要用于测试一些功能性的需求;比如网络请求,比如数据存储等等。

android studio对单元测试的支持:

新版的android studio中添加了对单元测试的支持;如图所示:
image

该目录下编写测试用例即可。

单元测试可以测试那些内容?

这里需要说明的是android studio的单元测试由于只是模拟android开发环境,但是其不是真正的android开发环境,所以不能测试UI功能,不能测试需要硬件支持的功能(比如蓝牙,wifi等),不能测试App跳转等等,那么其可以测试那些内容呢?

  • 测试一些数据性的功能,比如加载网络数据

  • 测试SharedPerferences,测试数据库,测试函数等

  • 工具类的测试,比如验证时间,转化格式,正则验证等等

简单的单元测试用例:

我们来看一下测试用例的写法:

/**
 * Instrumentation test, which will execute on an Android device.
 *
 * @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
 */
@MediumTest
@RunWith(AndroidJUnit4.class)
public class ExampleInstrumentationTest {
    @Test
    public void useAppContext() throws Exception {
        // Context of the app under test.
        Context appContext = InstrumentationRegistry.getTargetContext();

        assertEquals("uuch.com.android_activityanim", appContext.getPackageName());
    }
}

这是项目创建的默认的单元测试的类,可以看到其和普通的Class类无太多的区别,只是调用了相应的测试API而已,下面我们就自定义一个自己的单元测试类。

编写自定义的测试用例类:

  • 实现测试用例方法
/**
 * Created by aaron on 16/7/11.
 * 自定义的单元测试类
 */

@MediumTest
@RunWith(AndroidJUnit4.class)
public class MTest {

    @Test
    public void test1() {
        // Context of the app under test.
        Context appContext = InstrumentationRegistry.getTargetContext();
        assertEquals("uuch.com.android_activityanim", appContext.getPackageName());

        Log.i("tag", "$$$$$$$$$$$$");
        assertEquals("result:", 123, 100 + 33);
    }
}

需要注意的是

  • 测试用例类需要使用注解:@MediumTest和@RunWith(AndroidJUnit4.class)

  • 我们所写的测试用例方法需要添加名称为Test的注解,否则的话,就找不到测试方法。

比如我们去掉注解Test的话:
image

再次执行的话,就找不到可执行的测试函数了。

还有一个问题,可以发现我们的函数都是这是的public的,如果我们设置我们的测试函数为private的货怎么样呢?修改测试函数

@Test
    private void test2() {
        Log.i("tag", "$$$$$$$$$$$$");
        assertEquals("result:", 123, 100 + 33);
    }

执行之后可以发现:
image

报错了,错误说明也很详细,说的是我们的测试函数需要设置为Public的,所以我们在编写测试函数的时候需要注意两点:

  • 测试函数需要为public

  • 测试函数需要添加@Test注解

如何执行测试用例

  • 直接在源码中右键执行

编写完成之后,如何运行呢?
image

可以选中需要测试的方法名称,然后右击,弹出操作提示框,这是选择run 方法名就可以了,这时候就可以执行该测试方法了。

测试用例里面为我们提供了测试过程中可能需要的系统环境对象
image

比如:application,context等等;以后我们再次编写单元测试的时候是不是很方便了呢?

  • android studio菜单中执行测试用例

- 选择run-edit configuration
image

- 添加android tests用例
image

- 配置tests方法
image

点击ok,这时候run区域就已经出现了我们刚刚添加的测试用例了
image

一个简单的单元测试小例子:

说了这么多,我们还是举一个实力的开发例子吧。

  • 情景 有这样的一种情况,我们在开发过程中需要使用正则表达式验证一个字符串,但是我们想在重新编译Apk之前验证一下这个正则表达式,直接运行项目也可以打,但是太慢了,有什么简单的方式能够验证呢?这时候就可以使用我们的单元测试了。

  • 编码

@Test
    public void test2() {
        boolean result = "18210741899".matches("\\d{11}");
        Log.i("tag", "#####:" + result);
        /**
         * 验证邮箱
         */
        assertEquals("result:", result, true);
    }
  • 执行
    image

这样我们就可以不启动我们的App就验证正则表达式的正确与否了。

总结:

这样我们经过一系列的操作之后就介绍完了android studio中进行单元测试的步骤,怎么样?很简单吧,O(∩_∩)O哈哈~

  • android studio默认支持单元测试,可以在module下的androidTest下编写测试用例

  • 测试用例中提供了获取Context的API,可以通过该方法获取Context对象

  • 测试用例方法需要使用注解@Test表明,否则会报错,找不到测试方法

  • 测试方法需要定义为public,否则报错

  • 有两种执行测试方法的方式,可以直接在源码中右键执行,也可以在android studio中配置测试方法

  • 执行单元测试会重新执行apk的编译,打包,安装操作,其优势是帮你免去了手动的打开某个页面执行某个操作的步骤


另外对产品研发技术,技巧,实践方面感兴趣的同学可以参考我的:
android产品研发(一)-->实用开发规范
android产品研发(二)-->启动页优化
android产品研发(三)-->基类Activity
android产品研发(四)-->减小Apk大小
android产品研发(五)-->多渠道打包
android产品研发(六)-->Apk混淆
android产品研发(七)-->Apk热修复
android产品研发(八)-->App数据统计
android产品研发(九)-->App网络传输协议
android产品研发(十)-->不使用静态变量保存数据
android产品研发(十一)-->应用内跳转scheme协议
android产品研发(十二)-->App长连接实现
android产品研发(十三)-->App轮训操作
android产品研发(十四)-->App升级与更新
android产品研发(十五)-->内存对象序列化
android产品研发(十六)-->开发者选项
android产品研发(十七)-->Hybrid开发
android产品研发(十八)-->webview问题集锦