Android 单元测试 - Junit

1,217

基本用法实际操作

1、新建测试

public class Caculation {
    public double sum(double numA, double numB) {
        return numA + numB;
    }

    public double multiply(double numA, double numB) {
        return numA * numB;
    }
}

2、类名右键–Go To–Test,生成测试类
项目中androidTest文件夹里的就是UI测试代码,而test文件夹是Junit部分的单元测试代码。

3、编辑测试类,右键类名或者方法可运行得出测试结果

public class CaculationTest {
    private Caculation mCaculation;

    @Before
    public void setUp() throws Exception {
        mCaculation = new Caculation();
    }

    @Test
    public void sum() throws Exception {
        assertEquals(2,mCaculation.sum(1,1),0);
    }

    @Test
    public void multiply() throws Exception {
        assertEquals(10,mCaculation.multiply(2,5),0);
    }

}

Junit断言及注解说明

断言

  • assertArrayEquals(expecteds, actuals) 查看两个数组是否相等。
  • assertEquals(expected, actual) 查看两个对象是否相等。类似于字符串比较使用的equals()方法
  • assertNotEquals(first, second) 查看两个对象是否不相等。
  • assertNull(object) 查看对象是否为空。
  • assertNotNull(object) 查看对象是否不为空。
  • assertSame(expected, actual) 查看两个对象的引用是否相等。类似于使用“==”比较两个对象
  • assertNotSame(unexpected, actual) 查看两个对象的引用是否不相等。类似于使用“!=”比较两个对象
  • assertTrue(condition) 查看运行结果是否为true。
  • assertFalse(condition) 查看运行结果是否为false。
  • assertThat(actual, matcher) 查看实际值是否满足指定的条件
  • fail() 让测试失败

注意:上面的方法,都有一个重载的方法,可以在前面加一个String类型的参数,表示如果验证失败的话,将用这个字符串作为失败的结果报告。
比如:
assertEquals(“Current user Id should be 1”, 1, currentUser.id());

注解

  • @Before 初始化方法
  • @After 释放资源
  • @Test 测试方法,在这里可以测试期望异常和超时时间
  • @Ignore 忽略的测试方法
  • @BeforeClass 针对所有测试,只执行一次,且必须为static void
  • @AfterClass 针对所有测试,只执行一次,且必须为static void
  • @RunWith 指定测试类使用某个运行器
  • @Parameters 指定测试类的测试数据集合
  • @Rule 允许灵活添加或重新定义测试类中的每个测试方法的行为
  • @FixMethodOrder 指定测试方法的执行顺序

一个测试类单元测试的执行顺序为:
@BeforeClass –> @Before –> @Test –> @After –> @AfterClass
每一个测试方法的调用顺序为:
@Before –> @Test –> @After

打包测试

同样,如果一个项目中有很多个测试用例,如果一个个测试也很麻烦,因此打包测试就是一次性测试完成包中含有的所有测试用例。

@RunWith(Suite.class)  
@Suite.SuiteClasses({ AssertTests.class, CaculationTest.class, DemoTest.class })  
public class AllCaseTest {  

}  

需要向@RunWith注解传递一个参数Suite.class 。同时,我们还需要另外一个注解@Suite.SuiteClasses,来表明这个类是一个打包测试类。并将需要打包的类作为参数传递给该注解就可以了。至于AllCaseTest随便起一个类名,内容为空既可。运行AllCaseTest类即可完成打包测试

限时测试

在@Test后加入timeout参数

 @Test(timeout=1000)
    public void multiply() throws Exception {
        assertEquals(10,mCaculation.multiply(2,5),0);
    }

直接用@Rule设置该类的timeout参数

@Rule
    public Timeout globalTimeout = new Timeout(10000); // 10 seconds max per method tested  

验证方法会抛出某些异常

public class Calculator {

    // Omit testAdd() and testMultiply() for brevity

    public double divide(double divident, double dividor) {
        if (dividor == 0) throw new IllegalArgumentException("Dividor cannot be 0");

        return divident / dividor;
    }}
public class CalculatorTest {
    Calculator mCalculator;

    @Before
    public void setup() {
        mCalculator = new Calculator();
    }

    // Omit testAdd() and testMultiply() for brevity

    @Test(expected = IllegalArgumentException.class)
    public void test() {
        mCalculator.divide(4, 0);
    }

}

@Test(expected = IllegalArgumentException.class)表示验证这个测试方法将抛出IllegalArgumentException异常,如果没有抛出的话,则测试失败。