概述、Junit框架快速入门
单元测试
- 就是针对最小的功能单元(方法),编写测试代码对其进行正确测试。
之前进行的单元测试有什么问题?
- 只能在main方法编写测试代码,去调用其他方法进行测试。
- 无法实现自动化测试,一个方法测试失败,可能影响其他的方法的测试。
- 无法得到测试的报告,需要程序员自己去观察测试是否成功。
Junit单元测试框架
- 可以用来对方法进行测试,它是第三方公司开源出来的(很多开发工具已经集成了Junit框架,比如IDEA)
优点
- 开源灵活的编写测试代码,开源针对某个方法进行执行测试,也支持一键完成对全部方法的自动化测试,且各自独立。
- 不需要程序员去分析测试的结果,会自动生产测试报告出来。
具体步骤
- 将Junit框架的jar包导入到项目中(注意:IDEA集成了Junit框架,不需要我们手工导入了)
- 为需要测试的业务类,定义对应的测试类,并未每个业务方法,编写对应的测试方法(必须:公共、无参、无返回值)
- 测试方法上必须声明@Test注解,而后在测试方法中,编写代码调用被测试的业务方法进行测试
- 开始测试:选中测试方法,右键选择“JUnit运行”,如果测试通过则是绿色;如果测试失败,则是红色
StringJunit类
public class StringJunit {
public static void printNumber(String name){
if (name == null){
System.out.println(0);
return; //停掉方法
}
System.out.println("名字长度是:" + name.length());
}
public static int getMaxIndex(String data){
if (data == null){
return -1;
}
return data.length() - 1;
}
}
StringJunitTest类
import org.junit.Assert;
import org.junit.Test;
public class StringJunitTest {
@Test
public void testPrintNumber(){
StringJunit.printNumber("admin");
}
@Test
public void testGetMaxIndex(){
int index1 = StringJunit.getMaxIndex(null);
System.out.println(index1);
int index2 = StringJunit.getMaxIndex("admin");
System.out.println(index2);
// 断言机制:程序员可与通过预测业务方法的结果
Assert.assertEquals("方法内部有bug",4,index2);
}
}
Junit框架的常见注解
Junit单元测试框架的常用注解(Junit 4.xxx版本)
注解 | 说明 |
---|---|
@Test | 测试类中的方法必须用它修饰才能成为测试方法,才能启动 |
@Before | 用来修饰一个实例方法,该方法会在每一个测试方法执行之前执行一次 |
@After | 用来修饰一个实例方法,该方法会在每一个测试方法执行之后执行一次 |
@BeforeClass | 用来修饰一个静态方法,该方法会在所有测试方法之前只执行一次 |
@AfterClass | 用来修饰一个静态方法,该方法会在所有测试方法之后只执行一次 |
- 在测试方法执行前执行的方法,常用于:初始化资源。
- 在测试方法执行完后再执行的方法,常用于:释放资源。
Junit单元测试框架的常用注解(Junit 5.xxx版本)
注解 | 说明 |
---|---|
@Test | 测试类中的方法必须用它修饰才能成为测试方法,才能启动 |
@BeforeEach | 用来修饰一个实例方法,该方法会在每一个测试方法执行之前执行一次 |
@AfterEach | 用来修饰一个实例方法,该方法会在每一个测试方法执行之后执行一次 |
@BeforeAll | 用来修饰一个静态方法,该方法会在所有测试方法之前只执行一次 |
@AfterAll | 用来修饰一个静态方法,该方法会在所有测试方法之后只执行一次 |
- 开始执行的方法:初始化资源。
- 执行完之后的方法:释放资源。