您还未登录! 登录 | 注册 | 帮助  

您的位置: 首页 > 软件测试工具 > 白盒测试工具 > 正文

初入Android单元测试 - JUnit

发表于:2017-01-09 作者:最最最最醉人   来源:
  在《初入Android单元测试》中我们对Android单元测试有了一个大概的了解,今天我们就直接进入项目测试环节。直接用代码来学习单元测试。
  我们写单元测试,一般都会用到一个或多个单元测试框架,在这里,我们介绍一下JUnit4这个测试框架。这是Java界用的最广泛,也是最基础的一个框架,其他的很多框架,包括我们后面会看到的Robolectric,都是基于或兼容JUnit4的。
  在Android工程中引入JUnit
  在Android项目里面使用JUnit是很简单的,你只需要将JUnit这个library加到你的dependencies里面。   testCompile 'junit:junit:4.12'
  当然,如果你是通过Android Studio来创建的项目,那么这个dependency默认是加上了的,所以你甚至这步都可以省略。
  JUnit基本的使用
  当我们通过Android Studio创建好项目之后,我们在src/androidTest/java下,就会看到自动生成了的单元测试代码    JUnit
  虽然代码很少,但是在看代码之前,我们也先来学习一下JUnit中的一些知识点。
  @Test : 通过给某个方法添加这个注解,JUnit就会把它当作是一个需要测试的方法。   assertEquals(expected, actual):验证expected的值跟actual是一样的,如果是一样的话,测试通过,不然的话,测试失败。
  可以看到自动生成的代码中有一个useAppContext()的方法,该方法上面也标注了@Test注解,所以该方法是一个可以测试的方法,里面只有两行代码,它的作用就是判断当前测试的app包名是否等于"com.whyalwaysmea.junit"(当然,你的代码此处应该是你自己的包名)
  点击左侧的运行按钮,就可以直接对该方法进行测试运行了。如果包名和字符串相等,那么测试方法会运行成功,如果包名和字符串不相等,那么测试方法会报错,具体的可以看所打印出来的log
  JUnit的更多方法
  更多的注解:
  @Before: 如果一个方法被@Before修饰过了,那么在每个测试方法调用之前,这个方法都会得到调用。   @After: 每个测试方法运行结束之后,会运行的方法。比如一个测试文件操作的类,那么在它的测试类中,可能@Before里面需要去打开一个文件,而每个测试方法运行结束之后,都需要去close这个文件。这个时候就可以把文件close的操作放在@After里面,让它自动去执行。
  类似的,还有@BeforeClass和@AfterClass。@BeforeClass的作用是,在跑一个测试类的所有测试方法之前,会执行一次被@BeforeClass修饰的方法,执行完所有测试方法之后,会执行一遍被@AfterClass修饰的方法。   @Ignore: 很多时候,因为某些原因(比如正式代码还没有实现等),我们可能想让JUnit忽略某些方法,让它在跑所有测试方法的时候不要跑这个测试方法。要达到这个目的也很简单,只需要在要被忽略的测试方法前面加上@Ignore就可以了 。
  更多验证:
  assertEquals(expected, actual, tolerance)
  这里传入的expected和actual是float或double类型的,大家知道计算机表示浮点型数据都有一定的偏差,所以哪怕理论上他们是相等的,但是用计算机表示出来则可能不是,所以这里运行传入一个偏差值。如果两个数的差异在这个偏差值之内,则测试通过,否者测试失败。
  assertTrue(boolean condition)
  验证contidion的值是true
  assertFalse(boolean condition)
  验证contidion的值是false
  assertNull(Object obj)
  验证obj的值是null
  assertNotNull(Object obj)
  验证obj的值不是null
  assertSame(expected, actual)
  验证expected和actual是同一个对象,即指向同一个对象
  assertNotSame(expected, actual)
  验证expected和actual不是同一个对象,即指向不同的对象
  注意:上面的每一个方法,都有一个重载的方法,可以在前面加一个String类型的参数,表示如果验证失败的话,将用这个字符串作为失败的结果报告。
  比如:
  assertEquals("Current user Id should be 1", 1, currentUser.id());
  当currentUser.id()的值不是1的时候,在结果报道里面将显示"Current user Id should be 1",这样可以让测试结果更具有可读性,更清楚错误的原因是什么。
  总结
  该篇主要介绍了JUnit的一些基本使用,当然他的功能不仅仅限于此,毕竟他是java项目中使用最广泛的单元测试框架。因为本系列主要讲基本的Android单元测试,所以更深入的使用方式可以通过其他文章获取。