一、Mockito概念
引言
Mockito是Java生态系统中最受欢迎的单元测试模拟框架之一,以其简洁易用的API和强大的模拟能力赢得了广大开发者的青睐。Mockito允许我们在不实际依赖外部资源的情况下对代码进行彻底且高效的单元测试,极大地提升了测试覆盖率和代码质量。
什么是Mockito
Mockito是一种模拟框架,其核心概念是在测试过程中创建并使用“Mock对象”。Mock对象是对实际对象的一种模拟,它继承或实现了被测试类所依赖的接口或类,但其行为可以根据测试需求自由定制。控制其在测试环境下的行为,从而将注意力聚焦于类本身的逻辑验证上。
Mockito的优势
- 隔离度高:通过模拟依赖,减少测试间的耦合,确保单元测试真正只关注被测试单元的内部逻辑。
- 易于使用:API设计直观简洁,降低了编写和阅读测试用例的难度。
- 详尽的验证:能够准确跟踪和验证被测试对象与其依赖之间的交互行为。
- 灵活性强:支持多种定制模拟行为,无论是简单的返回值还是复杂的回调机制。
- 有利于TDD实践:与测试驱动开发方法论紧密契合,鼓励写出更易于测试的代码。
二、Mockito的主要功能点和方法使用
Mock 方法
- Mock对象创建
使用Mockito.mock()
方法创建接口或抽象类的Mock对象。
public static <T> T mock(Class<T> classToMock)
- classToMock:待 mock 对象的 class 类。
- 返回 mock 出来的类
实例:使用 mock 方法 mock 一个类
Random random = Mockito.mock(Random.class);
Mock对象进行行为验证和结果断言
使用 verify 验证
验证是校验对象是否发生过某些行为,Mockito 中验证的方法是:verify
。
verify(mock).someMethod("some arg");
verify(mock, times(1)).someMethod("some arg");
验证交换:Verify 配合 time() 方法,可以校验某些操作发生的次数。
注意:当使用 mock 对象时,如果不对其行为进行定义,则 mock 对象方法的返回值为返回类型的默认值。
/**
* 测试Mockito框架的使用,模拟Random类的nextInt方法。
* 该测试函数没有参数和返回值,主要用于演示Mockito的基本用法。
*/
@Test
public void test01() {
// 使用Mockito模拟一个Random对象
Random random = Mockito.mock(Random.class);
// 调用nextInt()方法,输出随机数,因random 行为为进行打桩,故输出默认值0(random.nextInt() 返回的是int类型)
System.out.println("第一次:"+random.nextInt());
// 指定当调用nextInt()时,始终返回1
Mockito.when(random.nextInt()).thenReturn(1);
System.out.println("第二次:"+random.nextInt()); // 再次调用nextInt(),输出应为1
// 断言nextInt()方法返回值是否为1
Assertions.assertEquals(1,random.nextInt());
// 验证nextInt()方法是否被调用了两次
verify(random, times(3)).nextInt();
}
断言使用到的类是 Assertions
Random random = Mockito.mock(Random.class);
Assertions.assertEquals(2, random.nextInt());
输出结果:断言nextInt()方法返回值是否为1
org.opentest4j.AssertionFailedError:
Expected :2
Actual :1
Mock对象打桩
打桩可以理解为mock
对象规定一行的行为,使其按照我们的要求来执行具体的操作。在Mockito
中,常用的打桩方法为
方法 | 含义 |
---|---|
when().thenReturn() | Mock 对象在触发指定行为后返回指定值 |
when().thenThrow() | Mock 对象在触发指定行为后抛出指定异常 |
when().doCallRealMethod() | Mock 对象在触发指定行为后调用真实的方法 |
thenReturn() 代码示例
@Test
void check() {
Random random = Mockito.mock(Random.class);
Mockito.when(random.