JUnit是用于编写可重复测试的单元测试框架,可实现自动化测试。
JUnit官方API文档:http://junit.org/junit4/javadoc/latest/index.html
创建测试类
以下内容使用Eclipse
添加JUnit library
Build Path - Add Libraries - JUnit
新建测试类
右键待测试类 - New - Other (Ctrl + N) - JUnit Test Case - Next - Select methods - Finished
命名规范
被测试类名为MyClass,位于默认source folder中的包com.mydemo.util。
package com.mydemo.util;
public class MyClass {
public static int add(int a, int b) {
return a + b;
}
}
新建source folder (可命名为test) 存放测试代码,在该folder下创建与被测试类同名包。测试类命名为MyClassTest,方法命名为testMethodName。测试方法前需加@Test,测试方法不能带参数,且必须为public void。
package com.mydemo.util;
import static org.junit.Assert.*;
import org.junit.Test;
import com.mydemo.util.MyClass;
public class MyClassTest {
@Test
public void testAdd() {
assertEquals(6, MyClass.add(3, 3));
}
}
使用测试类
运行测试类
测试失败
测试失败包括failure和error两种情况:
- Failure是断言内容不匹配,如
assertEquals(5, MyClass.add(3, 3));
- Error是程序存在Error或未处理的Exception,如
assertEquals(6, MyClass.add(3, a));
assertEquals(6, MyClass.divide(3, 0));
失败时,JUnit测试工具显示红色条,Failure Trace显示原因和位置。
注解Annotation
@Test
将普通方法注释为测试方法,方法内部使用断言,断言失败时测试失败。
- @Test(expected = ExceptionName.class)
表示预期会抛出的异常,如抛出声明类型的异常测试仍然显示成功。 - @Test(timeout = milliseconds)
表示超出时间测试程序自动结束并显示为失败,时间单位为毫秒。
@BeforeClass, @AfterClass, @Before, @After
- @BeforeClass
该方法在所有的方法运行前被执行,必须为static。当测试类被加载后接着就会被运行,且在内存中只会存在一份实例。可用于加载配置文件。 - @AfterClass
该方法在所有的方法运行结束后被执行,必须为static。通常用来对资源的清理,如关闭数据库的连接。 - @Before, @After
分别在每一个测试方法运行前、后被执行一次。可用于初始化变量或重置变量等。
@Ignore
被注释的测试方法会被测试运行器忽略,测试时不执行。
@RunWith
可以更改测试运行器,运行器需继承org.junit.runner.Runner。
测试套件
可用于多个测试类的同时测试。测试套件基本结构如下:
package com.mydemo.util;
import org.junit.runner.RunWith;
import org.junit.runners.Suite;
@RunWith(Suite.class)
@Suite.SuiteClasses({Test1.class,Test2.class,Test3.class, Suite1.class})
public class SuiteTest {
}
- 创建测试套件类SuiteTest.class,作为测试套件的入口类,这个类不包含任何方法。
- @RunWith(Suite.class) 更改测试运行器,避免使用JUnit默认测试运行器。
- @Suite.SuiteClasses({}) 添加测试类到测试套件中,参数为数组形式的测试类或测试套件类。
参数化测试
package com.mydemo.util;
import static org.junit.Assert.*;
import java.util.Arrays;
import java.util.Collection;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
// 更改默认测试运行器
@RunWith(Parameterized.class)
public class ParameterTest {
// 声明变量存放预期值和测试数据
int expected =0;
int input1 = 0;
int input2 = 0;
// public构造函数给预期值和测试数据赋值
public ParameterTest(int expected,int input1,int input2) {
this.expected = expected;
this.input1 = input1;
this.input2 = input2;
}
// 返回值为Collection的public static方法,返回测试数据集合,用@Parameters修饰
@Parameters
public static Collection<Object[]> data() {
return Arrays.asList(new Object[][]{
{3,1,2},
{4,2,2}
}) ;
}
@Test
public void testAdd() {
assertEquals(expected, MyClass.add(input1, input2));
}
}