JUnit4的API地址:
https://junit.org/javadoc/latest/index.html
JUnit4慕课学习地址:
https://www.imooc.com/learn/356
要点
1.测试方法上必须使用@Test进行修饰
2.测试方法必须使用public void 进行修饰,不能带任何的参数
3.新建一个源代码目录来存放我们的测试代码
4.测试类的包应该和被测试类保持一致
5.测试单元中的每个方法必须可以独立测试,测试方法间不能有任何的依赖
6.测试类使用Test作为类名的后缀(不是必须)
7.测试方法使用test作为方法名的前缀(不是必须)
Failure Error
1.Failure一般由单元测试使用的断言方法判断失败所引起的,这经表示 测试点发现了问题,就是说程序输出的结果和我们预期的不一样。
2.error是由代码异常引起的,它可以产生于测试代码本身的错误,也可以是被测试代码中的一个隐藏的bug。
3.测试用例不是用来证明你是对的,而是用来证明你没有错。
JUnit 运行流程
1.@BeforeClass修饰的方法会在所有方法被调用前被执行,该方法是静态的,所以当测试类被加载后接着就会运行它,而且在内存中它只会存在一份实例,它比较适合加载配置文件。
2.@AfterClass所修饰的方法通常用来对资源的清理,如关闭数据库的连接
3.@Before和@After会在每个测试方法的前后各执行一次。
JUnit 主要注解
@Test:将一个普通的方法修饰成为一个测试方法
@Test(expected=XX.class)
@Test(timeout=毫秒 )
@BeforeClass:它会在所有的方法运行前被执行,static修饰
@AfterClass:它会在所有的方法运行结束后被执行,static修饰
@Before:会在每一个测试方法被运行前执行一次
@After:会在每一个测试方法运行后被执行一次
@Ignore:所修饰的测试方法会被测试运行器忽略
@RunWith:可以更改测试运行器 org.junit.runner.Runner
测试套件
@RunWith(Suite.class)
@Suite.SuiteClasses({Test1.class,Test2.class,Test3.class})
public class Suite22Test {
/*
* 1.测试套件就是组织测试类一起运行的
*
* 写一个作为测试套件的入口类,这个类里不包含其他的方法
* 更改测试运行器@RunWith(Suite.class)
* 将要测试的类作为数组传入到@Suite.SuiteClasses({...})
*/
}
这里依次运行Test1,Test2,Test3 测试方法。
参数化设置
减少重复代码,提高可重用度
@RunWith(Parameterized.class)
public class Parameter22Test {
/*
* 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)); //Calculate是一个计算类,add()是加法。
}
}
Spring 与 JUnit4 的结合
public class SpringTest {
private static ApplicationContext context = null;
@BeforeClass
public static void setUpBeforeClass() throws Exception {
context = new ClassPathXmlApplicationContext("applicationContext.xml");
}
@Test
public void test() {
Date date = (Date) context.getBean("date");
System.out.println(date);
}
}
或者 直接可以用注解配置测试器,加载applicationContext.xml。
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class SpringTest {
@Test
public void test() {
Date date = (Date) context.getBean("date");
System.out.println(date);
}
}
JUnit 总结
JUnit很好,但测试用例是建立在对业务的深刻理解之上,只能帮你达到你的预期结果,你得首先保证你的预期结果就是业务的结果。