单元测试一、Junit
2018-01-26 本文已影响23人
爸比好酷
前言
Android Studio 以简化测试为设计宗旨。 您只需完成几次点击,便可建立一个在本地 JVM 上运行的 JUnit 测试,或建立一个在设备上运行的仪器测试
本地单元测试
适用场景:这些测试在计算机的本地 Java 虚拟机 (JVM) 上运行。 当您的测试没有 Android 框架依赖项或当您可以模拟 Android 框架依赖项时,可以利用这些测试来尽量缩短执行时间。
在应用模块的 build.gradle 文件中指定测试库依赖项:
dependencies {
// Required for local unit tests (JUnit 4 framework)
testCompile 'junit:junit:4.12'
}
手动建立
- 在左侧的 Project 窗口中,点击下拉菜单并选择 Project 视图。
- 展开相应的模块文件夹和嵌套的 src 文件夹。 要添加本地单元测试,请展开 test 文件夹和嵌套的 java 文件夹;要添加仪器测试,请展开 androidTest 文件夹和嵌套的 java 文件夹。
- 右键点击 Java 软件包目录并选择 New > Java Class。
- 命名文件,然后点击 OK。
AS自动创建
- 打开包含您想测试的代码的 Java 文件。
- 点击您想测试的类或方法,然后按 Ctrl+Shift+T (⇧⌘T)。
- 在出现的菜单中,点击 Create New Test。
- 在 Create Test 对话框中,编辑任何字段并选择任何要生成的方法,然后点击 OK。
- 在Choose Destination Directory 对话框中,点击与您想创建的测试类型对应的源集:androidTest 对应于仪器测试,test 对应于本地单元测试。
如图:
[图片上传失败...(image-49c0e7-1516945046776)]
编写测试代码
简单写一点点:
public class UtilsTest {
@Before
public void setUp() throws Exception {
MockitoAnnotations.initMocks(this);
System.out.println("setUp");
}
@Test
public void test1() throws Exception {
Assert.assertEquals(Utils.test1(),"is test1");
}
@Test
public void test2() throws Exception {
Assert.assertEquals(Utils.test2("1","2"),"21");
}
}
运行测试
要运行测试,请执行如下操作
- 点击工具栏中的 Sync Project,确保您的项目已与 Gradle 同步。
- 以下列其中一种方式运行测试:
1).在 Project 窗口中,右键点击测试,然后点击
2).来测试该类中的所有方法。 要运行所有测试,右键点击测试目录,然后点击 Run tests
- 以下列其中一种方式运行测试:
默认情况下,您的测试运行时使用的是 Android Studio 默认的运行配置。 如果您想更改某些运行设置(例如仪器运行器和部署选项),可以在 Run/Debug Configurations 对话框中编辑运行配置(点击 Run > Edit Configurations)
编写测试代码详解
Assert
[站外图片上传中...(image-bcceca-1516945046776)]
JUnit 中的注解及含义
[站外图片上传中...(image-cd8e55-1516945046776)]
超时
Junit 提供了一个指定超时参数。如果一个测试用例执行的毫秒数超过了指定的参数值,那么 Junit 将自动将它标记为失败。
@Test(timeout=1000)
public void test() {
...
}
捕获异常
@Test(expected = ArithmeticException.class)
public void testException() {
int b = 1/0;
System.out.println(b);
}