JUnit 5和Mockito单元测试

当谈及使用JUnit 5和Mockito进行单元测试时,了解如何结合两者来测试Java代码是至关重要的。在本文中,我们将深入探讨如何编写详细的单元测试,确保代码的可靠性和稳定性。

步骤一:设置项目依赖

首先,确保你的项目中包含了JUnit 5和Mockito的依赖。这两者可以通过Maven或Gradle进行添加。以下是Maven中添加依赖的示例:

xml 复制代码
<dependencies>
    <!-- JUnit 5 -->
    <dependency>
        <groupId>org.junit.jupiter</groupId>
        <artifactId>junit-jupiter-api</artifactId>
        <version>5.x.x</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.junit.jupiter</groupId>
        <artifactId>junit-jupiter-engine</artifactId>
        <version>5.x.x</version>
        <scope>test</scope>
    </dependency>
    
    <!-- Mockito -->
    <dependency>
        <groupId>org.mockito</groupId>
        <artifactId>mockito-core</artifactId>
        <version>x.x.x</version>
        <scope>test</scope>
    </dependency>
</dependencies>

步骤二:创建被测试的类

我们将从一个简单的示例开始。假设我们有一个名为 Calculator 的类,其中包含基本的数学运算方法。

java 复制代码
public class Calculator {
    public int add(int a, int b) {
        return a + b;
    }

    public int subtract(int a, int b) {
        return a - b;
    }
}

步骤三:编写单元测试

现在,让我们针对 Calculator 类编写单元测试。

java 复制代码
import org.junit.jupiter.api.Test;
import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;

public class CalculatorTest {

    @Test
    public void testAdd() {
        Calculator calculator = new Calculator();
        int result = calculator.add(10, 20);
        assertEquals(30, result, "10 + 20 should equal 30");
    }

    @Test
    public void testSubtract() {
        Calculator calculator = new Calculator();
        int result = calculator.subtract(20, 10);
        assertEquals(10, result, "20 - 10 should equal 10");
    }
}

这里,我们使用了JUnit 5的 @Test 注解来标记测试方法,并使用了 assertEquals() 方法来验证预期结果和实际结果是否相等。

步骤四:使用Mockito进行模拟

现在,假设 Calculator 类依赖于另一个类 MathUtil 来执行数学运算。

java 复制代码
public class MathUtil {
    public int multiply(int a, int b) {
        return a * b;
    }
}

我们可以使用Mockito来模拟 MathUtil 类,并对 Calculator 类进行更深入的测试。

java 复制代码
import org.junit.jupiter.api.Test;
import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;

public class CalculatorTest {

    @Test
    public void testMultiply() {
        MathUtil mathUtil = mock(MathUtil.class);
        when(mathUtil.multiply(2, 3)).thenReturn(6);

        Calculator calculator = new Calculator(mathUtil);
        int result = calculator.multiply(2, 3);
        
        assertEquals(6, result, "2 * 3 should equal 6");
    }
}

在这个示例中,我们使用了Mockito的 mock() 方法创建了一个 MathUtil 类的模拟对象,并使用 when().thenReturn() 方法设定了当调用 multiply() 方法时,返回预期的值。

将结合上面提供的几种情况,展示如何在一个单元测试类中使用JUnit 5和Mockito来编写不同类型的测试。

java 复制代码
import org.junit.jupiter.api.Test;
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.CsvSource;
import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;

public class CalculatorTest {

    @Test
    public void testAdd() {
        Calculator calculator = new Calculator();
        int result = calculator.add(10, 20);
        assertEquals(30, result, "10 + 20 should equal 30");
    }

    @Test
    public void testSubtract() {
        Calculator calculator = new Calculator();
        int result = calculator.subtract(20, 10);
        assertEquals(10, result, "20 - 10 should equal 10");
    }

    @ParameterizedTest
    @CsvSource({"2, 3, 6", "5, 5, 25", "4, 0, 0"})
    public void testMultiply(int a, int b, int expectedResult) {
        Calculator calculator = new Calculator();
        int result = calculator.multiply(a, b);
        assertEquals(expectedResult, result, () -> a + " * " + b + " should equal " + expectedResult);
    }

    @Test
    public void testComplexOperation() {
        MathUtil mathUtil = mock(MathUtil.class);
        Calculator calculator = new Calculator(mathUtil);

        calculator.complexOperation(3, 4);

        verify(mathUtil, times(1)).multiply(3, 4);
        verify(mathUtil, times(1)).multiply(anyInt(), eq(2));
    }

    @Test
    public void testDivideByZero() {
        Calculator calculator = new Calculator();

        Exception exception = assertThrows(IllegalArgumentException.class, () -> {
            calculator.divide(10, 0);
        });

        assertEquals("Divisor cannot be zero", exception.getMessage());
    }
}

这个例子展示了一个包含多种测试情况的单元测试类。其中包括了普通的方法测试、参数化测试、模拟对象的方法验证以及异常测试

总结

通过JUnit 5和Mockito,我们能够轻松地编写详细的单元测试。这种实践有助于确保代码在各种情况下都能按预期工作。JUnit 5提供了丰富的断言功能,而Mockito则帮助我们模拟和隔离依赖,从而更全面地测试代码。结合使用这两个工具,能够提高代码质量并降低潜在的错误风险。

相关推荐
Lisonseekpan15 小时前
Spring Boot Email 邮件发送完全指南
java·spring boot·后端·log4j
renke336418 小时前
Flutter 2025 测试工程体系:从单元测试到混沌演练,构建高可靠、可验证、自动化的质量保障闭环
flutter·单元测试·自动化
卓码软件测评19 小时前
软件测试:如何在Postman中配置和自动化OAuth 2.0与JWT认证?
测试工具·单元测试·自动化·测试用例·postman·可用性测试
要开心吖ZSH1 天前
Spring Boot + JUnit 5 + Mockito + JaCoCo 单元测试实战指南
java·spring boot·junit·单元测试
secondyoung1 天前
Pandoc转换Word文档:使用Lua过滤器统一调整Pandoc文档中的图片和表格格式
经验分享·junit·word·lua·markdown·pandoc·mermaid
Knight_AL1 天前
Redis Lua 脚本核心语法详解:KEYS[1]、ARGV[1]、tonumber 是什么意思?
redis·junit·lua
汽车仪器仪表相关领域2 天前
GZCVL T-II 安全防坠器测试系统
功能测试·测试工具·安全·单元测试·压力测试·可用性测试
木风小助理2 天前
分布式系统统一限流:基于Redis与Lua的跨实例流量管控方案
junit
小明的小名叫小明2 天前
Solidity入门(14)-Hardhat 3 单元测试基础与技巧
单元测试·区块链·solidity·hardhat
音浪豆豆_Rachel2 天前
Flutter跨平台通信的实战演练:复杂数据结构与单元测试在鸿蒙生态中的完美实现
数据结构·flutter·单元测试·harmonyos