深度剖析Android单元测试问题
作者:网络转载 发布时间:[ 2013/2/18 10:21:38 ] 推荐标签:
许多人在接触到Android单元测试时,第一反应是Android单元测试是不是已经完整集成了JUnit。很遗憾这不是事实。如果你按照JUnit的运行方法,却不像上面那样改用JDK,一定会得到一个异常。
实际上,TestCase这个类用于在Android担当所有独特的TestCase的基类的作用,它是一个Abstract Class。Android单元测试类继承关系图如下所示:
#
# An unexpected error has been detected by Java Runtime Environment:
#
# Internal Error (classFileParser.cpp:2924), pid=4900, tid=4476
#Error: ShouldNotReachHere()
#
# Java VM: Java HotSpot(TM) Client VM (10.0-b19 mixed mode windows-x86)
# An error report file with more information is saved as:
# E:MydocEclipseWorkspaceTestAndroidhs_err_pid4900.log
#
# If you would like to submit a bug report, please visit:
# http://java.sun.com/webapps/bugreport/crash.jsp
#
之所以有那么多XXXTestCase主要是为了简化工作。例如当你想对一个访问数据库的功能进行测试时,首先需要自己启动并初始化数据库。在这里是类似的,如果你想测试一个Activity。
首先要启动它。而ActivityTestCase会自动帮你做完这些事情。而ActivityUnitTestCase会更注重测试的独立性,它会让测试与Android单元测试的联系降到低。其余的类可以查看相关的Javadoc来按需挑选。要编写测试,是找到合适的XXXTestCase作为基类来继承,并且编写自己的测试方法。
很明显的,简单的编写测试的方法是继承Android单元测试写一个自己的TestCase。然后为自己的一组TestCase写一个Activity界面,由界面控制TestCase的启动,运行和结果报告。
但是,你很快会发现,为何要给测试写一个界面呢?这太诡异了。这时需要一种技术,它可以利用命令行(Shell)来启动一组测试,并且通过命令行的形式给出结果。这是所谓的Instrumentation。
在Java下做单元测试必然用到JUnit。这里说的JUnit是指从Apache基金会下载的junit.jar里提供的一系列单元测试功能。这些功能显然是运行在JDK之上的。在Android下已经没有了JDK。
自然也无法运行JUnit。但是这并不妨碍我们利用JUnit编写单元测试。只不过在运行单元测试时,一定要用JDK来运行,利用java命令来启动JUnit的某个Runner。如果是用Eclipse的话,可以在Run Configuration里新建一个JUnit。但是一定要记得在Classpath选项卡里将Bootstrap Entries中的Android Library改成JRE,并且添加junit.jar。
这样,在启动程序的时候会先启动一个Application,然后在此Application运行过程中根据情况加载相应的Activity,而Activity是需要一个界面的。但是Instrumentation并不是这样的。你可以将Instrumentation理解为一种没有图形界面的,具有启动能力的,用于监控其他类(用Target Package声明)的工具类。任何想成为Instrumentation的类必须继承
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11