Java基础--单元测试

JUnit是Java中最流行的开源单元测试框架,用于编写和运行可重复的、自动化的单元测试。JUnit极大地简化了测试用例的编写和组织,提供了丰富的断言方法、测试运行控制、测试结果报告等功能,是遵循测试驱动开发(TDD)和持续集成(CI)实践的重要工具。

步骤:

某个系统,有多个业务方法,请使用Junit框架完成对这些方法的单元测试。

具体步骤

Junit框架的jar包导入到项目中(注意:IDEA集成了Junit框架,不需要我们自己手工导入了)

编写测试类、测试类方法(注意:测试方法必须是公共的,无参数,无返回值的非静态方法)

必须在测试方法上使用@Test注解(标注该方法是一个测试方法)

在测试方法中,编写程序调用被测试的方法即可。

选中测试方法,右键选择“JUnit运行” ,如果测试通过则是绿色;如果测试失败,则是红色

junit常见注解

Junit 4.xxxx版本

                                                        说明

@Test

测试方法

@Before

用来修饰一个实例方法,该方法会在每一个测试方法执行之前执行一次。

@After

用来修饰一个实例方法,该方法会在每一个测试方法执行之后执行一次。

@BeforeClass

用来修饰一个静态方法,该方法会在所有测试方法之前只执行一次。

@AfterClass

用来修饰一个静态方法,该方法会在所有测试方法之后只执行一次

开始执行的方法:初始化资源。

执行完之后的方法:释放资源。

Junit 5.xxxx版本

注解

说明

@Test

测试方法

@BeforeEach

用来修饰一个实例方法,该方法会在每一个测试方法执行之前执行一次。

@AfterEach

用来修饰一个实例方法,该方法会在每一个测试方法执行之后执行一次。

@BeforeAll

用来修饰一个静态方法,该方法会在所有测试方法之前只执行一次。

@AfterAll

用来修饰一个静态方法,该方法会在所有测试方法之后只执行一次

基本概念

•测试类:每个测试类通常对应待测试的类或一组相关功能。测试类通常以Test结尾,且需继承junit.framework.TestCase或使用@RunWith(JUnit4.class)注解。

•测试方法:每个测试方法通常对应待测试类的一个具体功能点。测试方法名以test开头,无返回值,且不接受任何参数。测试方法内部使用JUnit提供的断言方法验证实际结果与预期结果是否相符。

•断言(Assertions):JUnit提供了丰富的断言方法,如assertEquals()、assertTrue()、assertNull()等,用于在测试方法中验证程序行为和结果。

•测试运行:JUnit通过junit.textui.TestRunner、IDE集成或构建工具(如Maven、Gradle)提供的插件运行测试。测试结果通常以通过/失败的形式显示,并提供详细的失败信息。

使用方法

1. 添加JUnit依赖:

        在Maven或Gradle项目中添加JUnit依赖。

Maven:

<dependencies>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.13.2</version>
        <scope>test</scope>
    </dependency>
</dependencies>

Gradle:

dependencies {
    testImplementation 'junit:junit:4.13.2'
}

2. 创建测试类:

创建一个继承junit.framework.TestCase或使用@RunWith(JUnit4.class)注解的公共类,类名通常以Test结尾。

import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class MyCalculatorTest {
    @Test
    public void testAdd() {
        MyCalculator calculator = new MyCalculator();
        int result = calculator.add(2, 3);
        assertEquals(5, result);
    }
}

3. 运行测试:

在IDE(如IntelliJ IDEA、Eclipse)中右键点击测试类或方法,选择“Run 'XXXTest'”。

也可通过命令行使用mvn test或gradle test运行所有测试。

高级特性

•注解:JUnit 4引入了大量的注解,如@Test、@Before、@After、@BeforeClass、@AfterClass、@Ignore、@Rule、@Parameterized等,用于标记测试方法、设置前置/后置操作、忽略测试、配置规则、参数化测试等。

•断言方法:除了基本的断言方法,JUnit还提供了更复杂的断言,如assertArrayEquals()、assertThat()(配合Hamcrest匹配器)、assertThrows()等,用于验证数组、集合、异常、对象属性等复杂情况。

•测试套件(Test Suite):使用junit.framework.TestSuite或@Suite注解将多个测试类组织成一个测试套件,一次性运行所有相关的测试。

•规则(Rules):JUnit规则(如TemporaryFolder、ExpectedException、ExternalResource等)提供了在测试前后进行资源管理、异常检查、外部资源清理等操作的通用机制。

•参数化测试(Parameterized Tests):使用@RunWith(Parameterized.class)和@Parameters注解,可以创建一组参数化测试用例,每个测试用例使用不同的输入数据运行相同的测试逻辑。

•异常测试:使用@Test(expected = SomeException.class)注解或assertThrows()方法,可以测试特定方法在特定条件下是否抛出预期的异常。

•第三方扩展:JUnit与许多第三方库(如Mockito、PowerMock、AssertJ、TestNG迁移工具等)兼容,可以进一步增强测试功能和易用性。

  • 24
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值