android上的单元测试

更新时间:2023-05-12 23:41:05 阅读: 评论:0

Android上的单元测试
IT168 技术文档】任何程序的开发都离不开单元测试来保证其健壮和稳定。Android的程序自然也不例外。从Android SDK 0.9开始,就有了比较成熟的测试框架,但是直到目前最新的1.1版本,也没有详细的文档介绍这个内容,只是简单的给了一个Api Demos里的几个单元测试代码。因此,我在这里对此内容做一下梳理和总结:
  JUnit还能用么?
  在 Java下做单元测试必然用到JUnit。这里说的JUnit是指从Apache基金会下载的junit.jar里提供的一系列单元测试功能。这些功能显然是运行在JDK之上的。在Android下已经没有了JDK,自然也无法运行JUnit。但是这并不妨碍我们利用JUnit编写单元测试。只不过在运行单元测试时,一定要用JDK来运行,利用java命令来启动JUnit的某个Runner。如果是用Eclip的话,可以在Run Configuration里新建一个JUnit。但是一定要记得在Classpath选项卡里将Bootstrap Entries中的Android Library文襄改成JRE,并且添加junit.jar
很明显的,这种测试就是正规的Java单元测试,和Android没有任何关系。你无法测试任何关于吾穆勒蓬灰牛肉面Android系统中的API,你写的Activity,人机界面等等。所以,如果你想测试仅仅是一些封装数据的对象,或者是纯粹的数值计算,还是可以用这种方法的。
  Android里面的junit.framework包是怎么回事?
  很多人看到这个包的时候,第一反应是Android是不是已经完整集成了JUnit。很遗憾这不是事实。如果你按照JUnit的运行方法,却不像上面那样改用JDK,就一定会得到一个异常:
  #
  # An unexpected error has been detected by Java Runtime Environment:
  #
  # Internal Error (classFileParr.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:\Mydoc\EclipWorkspace\TestAndroid\hs_err_pid4900.log
  #
  # If you would like to submit a bug report, plea visit:
  #/webapps/bugreport/crash.jsp
  #
  实际上,TestCa这个类用于在Android担当所有独特的TestCa的基类的作用,它是一个Abstract ClassAndroid单元测试类继承关系图如下所示:
  之所以有那么多XXXTestCa主要是为了简化工作。例如当你想对一个访问数据库的功能进行测试时,首先需要自己启动并初始化数据库。在这里是类似的,如果你想测试一个Activity投机取巧,首先要启动它。而ActivityTestCa零和竞争就会自动帮你做完这些事情。而 ActivityUnitTestCa会更注重测试的独立性,它会让测试与Android底层的联系降到最低。其余的类可以查看相关的Javadoc 来按需挑选。要编写测试,就是找到合适的XXXTestCa作为基类来继承,并且编写自己的测试方法。
  很明显的,最简单的编写测试的方法就是继承AndroidTestCa写一个自己的TestCa。然后为自己的一组TestCa写一个Activity界面,由界面控制 TestCa的启动,运行和结果报告。但是,你很快会发现,为何要给测试写一个界面呢?这太诡异了。这时就需要一种技术,它可以利用命令行(Shell)来启动一组测试,并且通过命令行的形式给出结果。这就是所谓的Instrumentation
什么是Instrumentation?
  一般在开发Android程序的时候,需要写一个manifest文件,其结构是:
<application android:icon="@drawable/icon" android:label="@string/app_name">
<activity android:name=".TestApp" android:label="@string/app_name">
……
</activity>
</application>
 
  这样,在启动程序的时候就会先启动一个Application,然后在此Application运行过程中根据情况加载相应的Activity,而Activity是需要一个界面的。但是introduce是什么意思Instrumentation牛奶鸡蛋羹并不是这样的。你可以将Instrumentation理解为一种没有图形界面的,具有启动能力的,用于监控其他类(初中生物课Target Package声明)的工具类。任何想成为Instrumentation的类必须继承android.app.Instrumentation。下面是这个类的解释:
  “Ba class for implementing application instrumentation code. When running with instrumentation turned on, this class will be instantiated for you before any of the application code, allowing you to monitor all of the interaction the system has with the ap
plication. An Instrumentation implementation is described to the system through l's tag.
  对于单元测试,我们需要认真了解的就是st.InstrumentationTestRunner类。这是Android单元测试的主入口。它相当于JUnit当中TestRunner的作用。
  那么如何加载它呢,首先要在manifest文件中加入一行关于Instrumentation的声明。比如Android Api Demos中的测试里的manifest是这么写的(我滤掉了所有的注释)
<manifest xmlns:android="/apk/res/android"

package="ample.sts">

<application>现在离过年还有多少天

<us-library android:name="st.runner" />

</application>

<instrumentation android:name="st.InstrumentationTestRunner"

android:targetPackage="ample.android.apis"

android:label="Tests for Api Demos."/>

</manifest>
  如果用EclipADT插件(0.8版本以上),也可以用图形界面来添加,如下图:
  编辑好 manifest,就可以打包(build,可以用Eclip ADT来做,也可以用aapt命令手工完成),然后安装到虚拟机上(adb install命令)。之后就可以利用命令行的方式来加载你的单元测试了。在Android Shell中加载一个Instrumentation的方法是利用以下命令:
  adb shell am instrument –w XXXXXX
  其中-w是指定Instrumentation类的参数标志。一个简单的例子是:
  adb shell am instrument -w com.android.st.InstrumentationTestRunner
  当然,也可以利用adb shell先进入android命令行模式,再直接写am instrument –w XXXXXXX。下面将具体介绍如何将根据需要加载一组单元测试。
如何在Android中利用Instrumentation来进行测试?
  在介绍具体的命令之前,我们先理解一下单元测试的层次。一组单元测试可以被组织成若干个TestSuite。每个TestSuite包含若干 TestCa(某个继承android.jarjunit.framework.TestCa的类)。每个TestCa又包含若干个 Test(具体的test方法)
  如果假设com.android.foo是你的测试代码的包的根。当执行以下命令时,会执行所有的TestCa的所有Test。测试的对象就是在Target Package中指定的包中的代码:
  adb shell am instrument -w com.android.st.InstrumentationTestRunner
  如果你想运行一个TestSuite,首先继承android.jarjunit.framework.TestSuite类,实现一个 TestSuite(比如叫com.android.foo.MyTestSuite),然后执行以下命令执行此TestSuite
  adb shell am instrument -e class com.android.foo.MyTestSuite -w com.android.st.InstrumentationTestRunner
  其中的-e表示额外的参数,语法为-e [arg1] [value1] [arg2] [value2] …这里用到了class参数。

本文发布于:2023-05-12 23:41:05,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/82/605977.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:测试   单元测试   启动   需要
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图