Android产品研发(十九)-->Android studio中的单元测试

转载请标明出处:一片枫叶的专栏

上一篇文章中我们讲解了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中添加了对单元测试的支持;如图所示:
Android产品研发(十九)-->Android studio中的单元测试_第1张图片

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

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

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

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

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

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

简单的单元测试用例:

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

/**
 * Instrumentation test, which will execute on an Android device.
 *
 * @see Testing documentation
 */
@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的话:
Android产品研发(十九)-->Android studio中的单元测试_第2张图片

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

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

/**
 * 单元测试,测试函数
 */
@Test
    private void test2() {
        Log.i("tag", "$$$$$$$$$$$$");
        assertEquals("result:", 123, 100 + 33);
    }

执行之后可以发现:
Android产品研发(十九)-->Android studio中的单元测试_第3张图片

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

  • 测试函数需要为public

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

如何执行测试用例

  • 直接在源码中右键执行

编写完成之后,如何运行呢?
Android产品研发(十九)-->Android studio中的单元测试_第4张图片

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

测试用例里面为我们提供了测试过程中可能需要的系统环境对象
Android产品研发(十九)-->Android studio中的单元测试_第5张图片

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

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

- 选择run-edit configuration
Android产品研发(十九)-->Android studio中的单元测试_第6张图片

- 添加Android tests用例
Android产品研发(十九)-->Android studio中的单元测试_第7张图片

- 配置tests方法
Android产品研发(十九)-->Android studio中的单元测试_第8张图片

点击ok,这时候run区域就已经出现了我们刚刚添加的测试用例了
Android产品研发(十九)-->Android studio中的单元测试_第9张图片

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

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

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

  • 编码

/**
 * 单元测试,测试函数
 */
@Test
    public void test2() {
        boolean result = "18210741899".matches("\\d{11}");
        Log.i("tag", "#####:" + result);
        /**
         * 验证邮箱
         */
        assertEquals("result:", result, true);
    }
  • 执行
    Android产品研发(十九)-->Android studio中的单元测试_第10张图片

这样我们就可以不启动我们的App就验证正则表达式的正确与否了。其中函数assertEquals为断言函数,用于判断结果是否正确,可以看到运行结果:1 test passed,说明我们的函数执行正确,即result为true,所以我们的正则表达式是正确的。

总结:

这样我们经过一系列的操作之后就介绍完了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问题集锦


本文以同步至github中:https://github.com/yipianfengye/AndroidProject,欢迎star和follow


你可能感兴趣的:(android产品研发,android产品研发)