Mockito 框架的 @Mock 和 @InjectMocks 注解使用指南

Mockito 与 @InjectMocks 简介

Mockito 是一个流行的 Java 测试框架,用于创建和验证单元测试中的模拟对象。@InjectMocks 注解是 Mockito 的一个特性,它能够自动注入使用 @Mock 注解创建的模拟对象。

手动创建测试实例的传统方法

在没有使用 @InjectMocks 之前,开发者可能需要手动创建被测试类的实例,并为其注入模拟的依赖对象。这通常涉及到直接使用 new 关键字创建对象,并将模拟对象传递给构造函数或 setter 方法。

@Mock 和 @InjectMocks 的自动化测试实例创建

Mockito 提供了 @Mock 注解来创建模拟对象,并通过 @InjectMocks 注解自动将这些模拟对象注入到被测试类的实例中。这种方式简化了测试代码的编写,提高了测试的效率。 UserService 类和测试类的示例
 

public class UserService {
    private UserDao userDao;

    public UserService(UserDao userDao) {
        this.userDao = userDao;
    }

    public UserDao getUserDao() {
        return userDao;
    }
}

@RunWith(MockitoJUnitRunner.class)
public class UserServiceTest {
    @Mock
    private UserDao userDao;

    @InjectMocks
    private UserService testMe;

    @Test
    public void testInjectMocks() {
        System.out.println(testMe.getUserDao().getClass());
    }
}


 
上面的测试用例演示了如何使用 @Mock 和 @InjectMocks 注解来创建 UserService 的测试实例。

@InjectMocks 的工作原理

@InjectMocks 注解会根据测试类中的 @Mock 字段,自动创建被测试类的实例,并将模拟对象注入到相应的字段中。它首先尝试使用非默认构造函数,如果没有合适的构造函数,则会使用 setter 方法或直接赋值。

@InjectMocks 注解的高级特性

@InjectMocks 注解在选择注入方式时有一定的顺序:首先是构造函数注入,然后是 setter 方法注入,最后是属性注入。如果存在多个构造函数,它会根据参数的数量选择最合适的构造函数。

 

@InjectMocks 与私有构造函数和 setter 方法

即使被测试类的构造函数或 setter 方法是私有的,@InjectMocks 也能够进行注入,因为 Mockito 在注入时会忽略 Java 的访问控制。

@InjectMocks 忽略含有基本类型参数的构造函数

如果构造函数包含基本类型参数,@InjectMocks 将不会使用该构造函数进行注入,因为基本类型无法模拟。

多个相同类型的 Mock 对象的名称匹配

当存在多个相同类型的 @Mock 对象时,@InjectMocks 可以通过 @Mock 注解的 name 属性进行匹配,确保正确的模拟对象被注入到正确的字段中。

@InjectMocks 与普通对象的区别

@InjectMocks 只能注入使用 @Mock 创建的模拟对象,如果字段是一个普通对象,@InjectMocks 将无法进行注入。

@Mock 和 @InjectMocks 的赋值行为

@Mock 和 @InjectMocks 会覆盖字段的初始值,即使字段已经被赋值,最终的值也是由 Mockito 模拟的对象。

使用 @Mock 对象创建实例的错误示例

错误的使用方式是在测试类中直接使用 new 关键字创建被测试类的实例,然后再尝试使用 @Mock 对象进行注入,这会导致模拟对象没有被正确注入。

静态测试类的使用示例

使用 PowerMock 可以对静态方法进行模拟,结合 @InjectMocks 使用,可以对涉及静态方法的测试类进行测试。

@RunWith(PowerMockRunner.class)
@PrepareForTest({
    SpringContext.class, KeywordRuleCacheData.class
})
public class KeywordRuleCacheDataRefreshDealTest {
    @InjectMocks
    KeywordRuleCacheDataRefreshDeal keywordRuleCacheDataRefreshDeal;

    @Test
    public void run() throws BaseAppException {
        PowerMockito.mockStatic(SpringContext.class);
        PowerMockito.mockStatic(KeywordRuleCacheData.class);
        PowerMockito.when(KeywordRuleCacheData.refushKeywordRuleCacheData()).thenReturn(true);
        keywordRuleCacheDataRefreshDeal.run();
    }
}

上面的示例展示了如何使用 PowerMock 和 Mockito 进行静态方法的模拟测试。
 

Java中,我们可以使用Mockito来进行测试用例的mockMockito是一个用于Java的开源测试框架,可以模拟对象、行为和方法,以便进行测试。 以下是一个简单的示例,展示了如何在Java中使用Mockito进行测试用例的mock: 假设我们有一个名为Calculator的类,其中包含一个add方法,用于将两个数字相加。我们希望测试这个方法,但是不想使用真正的数字进行测试,而是使用模拟数字来进行测试。 首先,我们需要在项目中引入Mockito框架的依赖项。在Maven项目中,可以像这样添加依赖项: ``` <dependency> <groupId>org.mockito</groupId> <artifactId>mockito-core</artifactId> <version>3.9.0</version> <scope>test</scope> </dependency> ``` 接下来,我们可以创建一个测试类,并使用Mockito来模拟数字: ``` import static org.mockito.Mockito.*; import org.junit.Test; public class CalculatorTest { @Test public void testAdd() { // 创建模拟数字 int num1 = mock(int.class); int num2 = mock(int.class); // 设置模拟数字的返回值 when(num1.intValue()).thenReturn(2); when(num2.intValue()).thenReturn(3); // 创建要测试的类 Calculator calculator = new Calculator(); // 调用add方法,并断言结果是否正确 int result = calculator.add(num1, num2); assertEquals(5, result); } } ``` 在上面的代码中,我们使用Mockitomock方法来创建模拟数字。我们还使用when方法来设置模拟数字的返回值。在测试方法中,我们创建了一个Calculator对象,并使用模拟数字调用了它的add方法。最后,我们使用断言来验证结果是否正确。 这只是Mockito的一个简单示例,Mockito还有许多其他功能,例如模拟方法和行为。如果您想深入了解Mockito,请查看官方文档:https://site.mockito.org/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据与算法架构提升之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值