Android单元测试-Junit
2017-03-11 本文已影响0人
oden
基本用法实际操作
CSDN同步发布
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异常,如果没有抛出的话,则测试失败。