自动化单元测试可以做许多的事,并帮你节省时间。它也可以被用作快速检验新建工程或进行冒烟测试。始终,单元测试是作为一种有效的、系统的检验应用程序各功能执行的方式。Android SDK支持JUnit的自动化单元测试。本教程假设你已熟悉Android和JUnit在Eclipse的使用。

创建一个Android的JUnit项目
如果你的Eclipse中已经有Android项目,就不用再创建了。如果你的Eclipse中没有Android项目,你可以创建一个JUnit项目,在创建JUnit项目的同时也会为你创建Android项目。

对现有的Android项目,在Eclipse中右键单击,选择“Android Tools”,然后“New Test Project...”,如下图:

如果是新建Android项目,在“New Android Project”对话框中,按“Next”按钮,如下图:

无论按照上面哪种方式,你都会在这个时候创建Android项目的新测试项目。创建测试项目的对话框,如下图所示,通常会自动填写上一些标准的命名约定等细节。如果没有,请自己填写,并创造该项目。


在Android中创建一个JUnit测试用例
Android应用程序通常是由一些Activity类组成的。事实上,每一个ACtivity都可以是一个独立实体,进行测试。Android SDK中包含了几个类来测试ACtivity类。现在我们将使用一个。

右键单击你的测试项目。选择“New”,然后“JUnit Test Case”:

在新建JUnit测试用例对话框上填写,使用超类是android.test.ActivityInstrumentTestCase2,其中T是我们要测试的Activity,如下图:

点击“完成”按钮,这个类就创建成功了。注意:由向导创建的默认构造函数是不正确的。我们需要修改它,让它不带任何参数,调用不同的super()的方法,代码如下:

1 public ScreenValidation() {
2    super("com.mamlambo.testingproject.TestingProjectActivity",
3      TestingProjectActivity.class);
4 }

setUp()方法中,应配置运行这个测试用例所需的所有东西。Activity实例随时可以被getActivity()方法调用。例如:如果我们想在测试中显示一个TextView在Activity上,我们可以实现setUp()方法,如下:

1 TextView helloText;
2 protected void setUp() throws Exception {
3   super.setUp();
4   helloText = (TextView) getActivity().
5      findViewById(R.id.hello_textview);
6 }

在Android中添加单元测试
此时你可以创建各种测试。你可以获取到Activity布局上所有控件,以及在应用程序的任何代码。由于使用Activity测试用例,我们可能感兴趣于用户界面,布局,及功能。让我们看看TextView控件显示在屏幕上。

01 public void testHelloTextVisibility() {
02    View container = getActivity().findViewById(R.id.container_layout);
03    int boundaryWidth = container.getWidth();
04    int boundaryHeight = container.getHeight();
05  
06    int[] location = new int[2];
07    container.getLocationOnScreen(location);
08  
09    int[] helloTextLocation = new int[2];
10    helloText.getLocationOnScreen(helloTextLocation);
11  
12    Rect textRect = new Rect();
13    helloText.getDrawingRect(textRect);
14  
15    boolean widerThanBoundary = (textRect.width() > boundaryWidth);
16    boolean tallerThanBoundary = (textRect.height() > boundaryHeight);
17    boolean extendsOffRight = location[0] + boundaryWidth
18      > helloTextLocation[0] + textRect.width();
19    assertTrue("Text wider than boundary", widerThanBoundary);
20    assertTrue("Text taller than boundary", tallerThanBoundary);
21    assertTrue("Text goes off right side", extendsOffRight);
22  
23    // ... and so on
24  }

所有的测试方法必须用“test”做前缀。上面,我们已经创建了一个测试名为“HelloTextVisibility”的方法。如果测试通过或失败,assertFalse()都会被调用。(assertTrue()方法只有是true时调用。)

运行JUnit测试用例
运行测试和测试用例,点击Eclipse的Debug,选择Android JUnit测试。如果你喜欢,你还可以创建一个Android JUnit测试配置,自定义这些设置。
如下图,我们的小应用程序在横屏模式下,“Hello Text Visibility”测试通过:

但在竖屏模式下,未能通过测试:

很显然,我们的布局设计在竖屏模式下显示不正确。(注:这可能是设置的宽度像素超过了手机的,而没有使用合适的单位,如DP或是match_parent。)

Android应用程序的质量在于单元测试
创建单元测试时,必须小心谨慎。如果测试用例不正确,测试的东西通过了,也没有价值。这是非常糟糕的,因为它可能掩盖了一些问题。所以测试用例与代码本身一样重要。测试测试用例的主要方式是通过做代码审查,并确保它们确实在测试。

当然,测试Android框架的功能对于你的app来说,没有起到特别大的作用。比如,测试设置文本字段的值,然后读取它,看它是否相同。测试常规的TextView,并不是特别有意义的(除非你的SDK在一个新的设备上使用)。然而,如果是测试你自己实现的TextView,那就有必要了。

这并不是说任何代码框架都是那样的完美无缺,但测试的事情是值得花许多心思的去写测试开始的。如果失败了,比起的你的应用程序,你将有更大的问题。还有是对SDK之间的细微差别的测试,在上面的例子中,我们没有这么做,是因为我们使用了正确的SDK。

因此,如果你是自动化单元测试的新手,我们建议你做一些这方面的课题研究。一个不错的地方是JUnit.org

结论
在本教程中,你已经学会如何快速添加一个新的测试项目,并在Eclipse的Android项目中使用JUnit对你的app执行自动化测试。单元测试可以为逻辑测试,功能测试和用户界面测试等,不再是专门手动测试移动应用。然而,使用一个包含自动化单元测试的套件,有几大好处:它可以节省时间,金钱和资源,以及提供一套可靠的,重复性的测试,并且可以运行在许多不同的设备配置中。

Android JUnit 入门指南的更多相关文章

  1. Android Studio入门指南 (历上最全,全球首发)

    下载地址:http://pan.baidu.com/s/1CEMma 8月份的时候因为Android开发团队全部使用Android Studio进行开发,所以我整理了Android Studio的一些 ...

  2. Android Studio 入门指南

    转载: 原文链接:http://www.codeceo.com/article/android-studio-guide.html 写在前面 作为一个Android 开发者,你应该很了解Android ...

  3. android -------- NDK 入门指南

    NDK介绍 原生开发工具包 (NDK) 是一组可让您在 Android 应用中利用 C 和 C++ 代码的工具. 可用以从您自己的源代码构建,或者利用现有的预构建库. NDK 不适用于大多数初学的 A ...

  4. Android(Lollipop/5.0) Material Design(二) 入门指南

    Material Design系列 Android(Lollipop/5.0)Material Design(一) 简介 Android(Lollipop/5.0)Material Design(二) ...

  5. Android 虚拟现实(virtual reality)入门指南

    入门指南 本文档介绍怎样使用实验性的 Cardboard SDK for Android 创建您自己的虚拟实境 (VR) 体验. Android 演示版应用:Treasure Hunt 本教程中的代码 ...

  6. [译]:Xamarin.Android开发入门——Hello,Android Multiscreen深入理解

    原文链接:Hello, Android Multiscreen_DeepDive. 译文链接:Xamarin.Android开发入门--Hello,Android Multiscreen深入理解. 本 ...

  7. [译]:Xamarin.Android开发入门——Hello,Android深入理解

    返回索引目录 原文链接:Hello, Android_DeepDive. 译文链接:Xamarin.Android开发入门--Hello,Android深入理解 本部分介绍利用Xamarin开发And ...

  8. [译]:Xamarin.Android开发入门——Hello,Android快速上手

    返回索引目录 原文链接:Hello, Android_Quickstart. 译文链接:Xamarin.Android开发入门--Hello,Android快速上手 本部分介绍利用Xamarin开发A ...

  9. 一起学微软Power BI系列-官方文档-入门指南(7)发布与共享-终结篇+完整PDF文档

    接触Power BI的时间也只有几个月,虽然花的时间不多,但通过各种渠道了解收集,谈不上精通,但对一些重要概念和细节还是有所了解.在整理官方文档的过程中,也熟悉和了解了很多概念.所以从前到后把微软官方 ...

随机推荐

  1. mybatis映射文件遇到的小问题

    mybatis的映射文件插入操作时: 如果对应的属性是String类型的,那么一定要做空串的判断. 比如注册的时候,如果需要向数据库中插入一条记录时,对应的字段没有给他赋值,这个String类型的值传 ...

  2. Anagrams leetcode java

    题目: Given an array of strings, return all groups of strings that are anagrams. Note: All inputs will ...

  3. CentOS 7 开放防火墙端口命令

    CentOS 7 开放防火墙端口 命令 最近公司新的server要求用CentOS7, 发现以前CentOS 6 系列中的 iptables 相关命令不能用了,查了下,发现Centos 7使用fire ...

  4. 关于opacity的思考

    今天在封装图片轮播的插件的时候,产生了这个opacity的小小思考. 我这个轮播的思路不是以前baidu输入法官网的设置外层容器overflow为hidden,position为relative用se ...

  5. 【NodeJS】nvm、npm、node安装、使用、淘宝源设置等资料

    NodeJS-安装使用淘宝源 管理 node 版本,选择 nvm 还是 n? - WEB前端 - 伯乐在线 creationix/nvm: Node Version Manager - Simple ...

  6. 关于帝国CMS迁移到新服务器上出现问题的处理办法

    在帝国CMS项目整体迁移过程中,或多或少总会出点幺蛾子,以下就常见的注意事项整理一下: 一.修改 e/config/config.php中的数据库相关配置 二.让项目文件位置具有读写权限 三.设置ph ...

  7. IDEA报错Target level '1.6' is incompatible with source level '1.7'

    解决IDEA 编译级别 Error:java: Target level '1.6' is incompatible with source level '1.7'. A target level ' ...

  8. easyui combobox实现本地模糊查询

    直接上代码 $("#combobox1").combobox({ valueField : "value", textField : "text&qu ...

  9. Memcached--分布式缓存安装教程

    Memcached的Windows版本在这里下载http://code.google.com/p/memcached/wiki/PlatformWindows(或http://memcachedpro ...

  10. Objective-C中NSString与int和float的相互转换

    NSString *tempA = @"123"; NSString *tempB = @"456"; 1,字符串拼接 NSString *newString ...