JUnit简介
- xUnit是一套基于测试驱动开发的测试框架
- JUnit3中所有方法都必须使用@Test注解,需要在方法名前加test作为前缀,必须继承junit.framework.TestCase类。
- JUnit4:只要加上@Test注解即可,不需要继承任何类,命名没有限制。
- assertEquals( , ); 使用断言测试:第一个参数代表预期值,第二个参数代表程序计算出的实际值。(断言机制:将程序预期的结果与程序运行的最终结果进行比对,确保对结果的可预知性。)
JUnit4的使用
- 测试方法上必须使用@Test进行修饰
- 测试方法必须使用public void 进行修饰,不能带任何的参数
- 新建一个源代码目录来存放我们的测试代码
- 测试类的包应该和被测试类保持一致
- 测试单元中的每个方法必须可以独立测试,测试方法间不能有任何的依赖
- 测试类使用Test作为类名的后缀
- 测试方法使用test作为方法名的前缀
测试失败的两种情况:
- Failure一般由单元测试使用的断言方法判断失败所引起的,这表示测试点发现了问题,就是说程序输出的结果和我们预期的不一样。
- error是由代码异常引起的,它可以产生于测试代码本身的错误,也可是被测试代码中的一个隐藏的bug
- 测试用例不是用来证明你是对的,而是用来证明你没有错
测试用例用来达到想要的预期结果,但对于逻辑错误无能为力
JUnit运行流程:
- @BeforeClass修饰的方法会在所有方法被调用前执行,而且该方法是静态的,所以当测试类被加载后接着就会运行它,而且在内存中它只会存在一份实例,它比较适合加载配置文件
- @AfterClass所修饰的方法通常用来对资源的清理,如关闭数据库的连接
- @Before和@After会在每个测试方法的前后各执行一次
JUnit常用注解:
- @Test:将一个普通的方法修饰成为一个测试方法
- @Test(expected=XX.class)检查被测方法是否抛出XX异常,只有抛出该异常时才算成功,其他所有情况都是失败或错误
- @Test(timeout=毫秒)设置执行的时间,用于结束死循环或是性能测试
- @BeforeClass:它会在所有的方法运行结束前被执行,static修饰
- @AfterClass:它会在所有的方法运行结束后被执行,static修饰
- @Before:它会在每一个测试方法被运行前执行一次
- @After:会在每一个测试方法运行后被执行一次
- @Ignore:所修饰的测试方法会被测试运行器忽略
- @RunWith:可以更改测试运行器 org.junit.runner.Runner
JUnit4的深入使用
JUnit4测试套件的使用:
@RunWith(Suite.class)
@Suite.SuiteClasses({TaskTest1.class,TaskTest2.class,TaskTest3.class})
public class SuiteTest {
/*
* 1.测试套件就是组织测试类一起运行的
*
* 写一个作为测试套件的入口类,这个类里不包含其他的方法
* 更改测试运行器Suite.class
* 将要测试的类作为数组传入到Suite.SuiteClasses({})
*/
}
public class TaskTest1 {
@Test
public void test() {
System.out.println("this is TaskTest1...");
}
}
public class TaskTest2 {
@Test
public void test() {
System.out.println("this is TaskTest2...");
}
}
public class TaskTest3 {
@Test
public void test() {
System.out.println("this is TaskTest3...");
}
}
JUnit4参数化设置:
public class Calculate {
public int add(int a,int b){
return a+b;
}
public int substract(int a , int b){
return a-b;
}
public int mutiply(int a,int b){
return a*b;
}
public int divide(int a, int b){
return a/b;
}
}
@RunWith(Parameterized.class)
public class ParameterTest {
/*
* 1.更改默认的测试运行器为RunWith(Parameterized.class)
* 2.声明变量来存放预期值 和结果值
* 3.声明一个返回值 为Collection的公共静态方法,并使用@Parameters进行修饰
* 4.为测试类声明一个带有参数的公共构造函数,并在其中为之声明变量赋值
*/
int expected =0;
int input1 = 0;
int input2 = 0;
@Parameters
public static Collection<Object[]> t() {
return Arrays.asList(new Object[][]{
{3,1,2},
{4,2,2}
}) ;
}
public ParameterTest(int expected,int input1,int input2) {
this.expected = expected;
this.input1 = input1;
this.input2 = input2;
}
@Test
public void testAdd() {
assertEquals(expected, new Calculate().add(input1, input2));
}
}