Junit单元测试
介绍
一个用于编写和执行java单元测试的框架,可以帮助开发人员验证代码
单元测试
一种测试方法,用于校验程序中的最小可测试单元(通常是一个方法)是否按照预期工作.
JUnit提供了一组注解和断言方法,使编写和执行单元测试变得更加方便
在开发过程中可以频繁运行单元测试来验证代码正确性,可以尽早发现和修复错误,提高开发效率.
使用步骤
1,导入Junit框架jar包到项目中
2,为需要的业务类定义测试类,并为每个业务方法编写测试方法
公共,无参,无返回值
3,测试方法上必须声明@Test注解,在测试方法中编写代码调用需要被测试的方法测试
4,选中测试方法,右键选择"JUnit运行"
如果测试通过为绿色,失败为红色
测试方法
断言:
Assert.assertEquals(result1,result2)
//result1为预想的结果
//result2为调用测试方法得到的结果
//断言预期结果与实际结果是否相等
常用注解
@Test
//测试类中方法必须用它修饰才能成为测试方法,才能被JUnit启动执行
@Before
//用来修饰一个实例方法,会在每个!测试方法前执行一次
@After
//用来修饰一个实例方法,会在所有测试方法后执行一次
@BeforeClass
//用来修饰一个静态方法,会在所有测试方法前执行一次
@AfterClass
//用来修饰一个静态方法,该方法会在所有测试方法之后执行一次
案例
public class Calculator {
/**
* 该方法用于计算两个整数的和。
*
* @param a 被加数
* @param b 加数
* @return 两个整数的和
*/
public int add(int a, int b) {
return a + b;
}
/**
* 该方法用于计算两个整数的差。
*
* @param a 被减数
* @param b 减数
* @return 两个整数的差
*/
public int subtract(int a, int b) {
return a - b;
}
/**
* 该方法用于计算两个整数的乘积。
*
* @param a 被乘数
* @param b 乘数
* @return 两个整数的乘积
*/
public int multiply(int a, int b) {
return a * b;
}
/**
* 该方法用于计算两个整数的商。
*
* @param a 被除数
* @param b 除数
* @return 两个整数的商
* @throws ArithmeticException 如果除数为0,则抛出算术异常
*/
public int divide(int a, int b) {
if (b == 0) {
throw new ArithmeticException("除数不能为0");
}
return a / b;
}
}
根据以上代码我们可以创建一系列测试代码
public class CalculatorTest {
@org.junit.Test
public void add() {
Calculator cal = new Calculator();
int result = cal.add(1,2);
Assert.assertEquals(4,result);//断言结果为4
}
@org.junit.Test
public void subtract() {
}
@org.junit.Test
public void multiply() {
}
@org.junit.Test
public void divide() {
}
@Before
public void start(){
System.out.println("method_begin");//在方法前打印
}
@After
public void end(){
System.out.println("method_end");//在方法后打印
}
@BeforeClass
public static void BeforeClass(){
System.out.println("Start...");//在类创建时打印
}
@AfterClass
public static void AfterClass(){
System.out.println("...End");//在类结束时打印
}
}
运行结果如下