自动化测试作为整个产品生命周期过程中必不可少的一部分,可以得到快速的反馈,提前发现错误进行改正,避免把错误暴露在用户手中,同时也可以较少项目开销、缩短项目周期。
Local JUnit 和 Instrumented JUnit
Android测试是基于JUnit,可以分为两大类:
- 依赖本地JVM的JUnit测试(Local JUnit), 测试用例在
module-name/src/test/java/目录下, 不能访问Android框架功能; - 依赖Android手机的设备化测试(Instrumented JUnit), 测试用例在
module-name/src/androidTest/java/目录下; 必须要运行在Android真机或虚拟机;
两者的对比如下:

| test types | description |
|---|---|
| Local unit test/Small tests | 测试用例只在本地JVM上运行, 当测试用例中没有Android框架或者可以mock Android框架时,这类测试用例可以最大化的减少运行时间 |
| Instrumented unit test/ Medium tests |
测试用例必须要运行在Android设备或者虚拟机上, 可以获取设备信息等一系列信息, eg: Contex; |
| Components within your app only/ Large tests | 集成测试,UI测试,只能在一个app内部进行测试,eg:Espresso; |
| Cross-app Components / Large tests |
集成测试,UI测试,可以跨多个app进行测试,eg:UI Automator; |
公共API
@Before: 测试用例初始化操作,在测试类内部的每个测试方法运行之前都会运行一次该初始化方法,可以定义多个以@Before注释的方法;@After: 测试用例收尾,包括释放资源和内存等。在测试类内部的每个测试方法运行之后都会运行一次该初始化方法,可以定义多个以@After注释的方法;@Test: 一条测试用例;@Rule: 为了灵活并且重复定义每个测试方法的表现形式,Android测试中主要有ActivityTestRule 和 ServiceTestRule;@BeforeClass: 测试的初始化方法,和@Before的区别在于:@BeforeClass注释的方法在整个测试类中只运行一次,主要用于一些比较耗时或者耗费资源的操作;@AfterClass: 测试的初始化方法,和@After的区别在于:@AfterClass注释的方法在整个测试类中只运行一次,主要用来释放资源;@Test(timeout=expectedTime): 超时测试,用例耗时超过一个确定的时间则判断该测试用例失败,eg: @Test(timeout=500);@Test(expected ...): 异常测试,期望测试方法抛出异常;@Ignore: 跳过某个测试方法不执行;
Android Testing Support Library
Android Testing Support Library提供了一组APIs,利用这些APIs可以快速的建立和运行测试用例,包括JUnit测试和UI测试,包括以下几类API:
Espresso: UI测试框架,只能在一个app内部进行测试,不能跨app;UI Automator: UI测试框架,可以跨多个app进行测试;AndroidJUnitRunner: 针对android的junit4 测试框架;
主要框架
- Local JUnit 的测试框架主要有:
Robolectric:是一个可以在JVM上运行Android框架相关的框架,可以测试控件、组件、资源等;mock:mock 是一个可以模拟类、接口、方法等的框架,可以模拟android框架相关的部分;powerMock:和 mock 功能类似,但是比 mock 更强大,可以 mock 私有、静态、final等类和方法;
- Large tests 的测试框架主要有:
Android JUnit4 Rules:可以测试 Activity 或者 Service 等;Espresso:UI 测试框架,只能在同一个 App 内部进行测试,不能和其它 App 进行交互;UI Automator:UI 测试框架,可以和系统应用、其它应用进行交互;