mockito的详细使用

简介: 1.概述mock,一种JAVA单元测试技术,mock允许使用模拟对象替换测试中的系统部件,并断言它们是如何被使用的一项技术。当某个接口或者功能模块依赖于其他接口或者模块,而所依赖的模块或接口未开发完毕,可以使用mock模拟依赖的模块。mockito,JAVA单元测试中使用频率最高的mock框架之一。mock遵循流程:输入—期望—验证

1.概述

mock,一种JAVA单元测试技术,mock允许使用模拟对象替换测试中的系统部件,并断言它们是如何被使用的一项技术。

当某个接口或者功能模块依赖于其他接口或者模块,而所依赖的模块或接口未开发完毕,可以使用mock模拟依赖的模块。

mockito,JAVA单元测试中使用频率最高的mock框架之一。

mock遵循流程:输入—期望—验证

2.使用

2.1.依赖

注释:博主用的3.8.0,具体版本号有哪些可以去maven repository上查。

<dependency>

    <groupId>org.mockito</groupId>

    <artifactId>mockito-core</artifactId>

    <version>${version}</version>

    <scope>test</scope>

</dependency>

2.2.校验

2.2.1.值校验

校验值是否是期待值。

178599ecc713438493a2591bfc55ad8e.png

2.2.2.顺序校验

inOrder可以校验方法的调用顺序是否是按照之前的调用顺序。

2849a9e88e274f04939d359943d85c0b.png

2.2.3.指定返回

指定返回值是mock的最大价值也是最常用的,指定返回值可以用来伪造一个假的返回值,从而绕过对于真实对象的调用。如果真实对象的调用很复杂,入参或者调用条件很苛刻,那么直接用mock的指定返回功能绕过即可,这是很有价值的。

439453fa27a64f88a2be2841a01b7680.png

注意:

mock只是生成了一个壳子,不是真的创建了一个对象,无法进行状态的维护,需要对每个行为对应的属性都要进行自定义,如以下代码即使调用了set方法,也不会为属性赋值,属性仍然为null。

@Test
public void test(){
  Person mockPerson=Mockito.mock(Person.class);
    mockPerson.setName("bugMan");
    assert mockPerson.getName()==null:"name属性值为空";
}

2.3.注解

除了编码的方式外,还提供了注解方式进行使用,从而使代码变得更加简洁。

2.3.1.@Mock

@Mock和Mockito.mock()功能相同。

@Mock
HashMap<String, Integer> mockHashMap;
@Test
public void saveTest()
{
    //输入
    mockHashMap.put("A", 1);
  //期望
    Mockito.verify(mockHashMap).put("A", 1);
    assert mockHashMap.size()==0;
}

2.3.2.@Spy

@Spy和@Mock不同的是@Mock创建的是个壳子,而@Spy创建的真的是个对象,可以进行状态维护。

@Spy
HashMap<String, String> hashMap;
@Test
public void saveTest()
{
  //输入
    hashMap.put("name", "bugMan");
  //期望
    Mockito.verify(hashMap).put("name", "bugMan");
    assert hashMap.size()==1;
}

2.3.3.@Captor

@Captor注释用于创建ArgumentCaptor对象,该类型的对象可以用来捕获参数。

@Mock
HashMap<String, String> hashMap;
@Captor
ArgumentCaptor<String> keyCaptor;
@Captor
ArgumentCaptor<String> valueCaptor;
@Test
public void saveTest() 
{
    hashMap.put("name", "bugMan");
    Mockito.verify(hashMap).put(keyCaptor.capture(), valueCaptor.capture());
    assert "name".equals(keyCaptor.getValue());
    assert "bugMan".equals(valueCaptor.getValue());
}

2.3.4.@InjectMocks

@InjectMocks用来进行@Mock的注入,目的就是去掉手动注入,让代码变得简洁。

以一个service层注入dao层的操作为例:

dao层:

@Repository
public class MyRepository {
    public void doSomething() {
        System.out.println("here's dosomething");
    }
    public Model findById(Long id) {
        return new Model(id, "Real Repository");
    }
}

service层:

@Service
public class MyService {
    @Autowired
    private MyRepository myRepository;
    public void doSomething() {
        this.myRepository.doSomething();
    }
    public Model findById(Long id) {
        return this.myRepository.findById(id);
    }
}

没有@InjectMocks的话,需要手动注入:

MyRepository myRepository = Mockito.mock(MyRepository.class); 
MyService myService = new MyService(myRepository);

有@InjectMocks的话直接声明即可,@Mock注解的对象会自动注入进@InjectMocks注解的对象:

  @Mock
    private MyRepository myRepository;
    @InjectMocks
    private MyService myService;
    @Test
    public void testInjectMocks() {
        System.out.println(myService.getMyRepository().getClass());
    }


目录
相关文章
|
1月前
|
开发工具 C++ 开发者
如何判断电脑上已安装了哪些版本的VC运行库?
本文介绍如何检测电脑中已安装的VC运行库(Microsoft Visual C++ Redistributable)版本,涵盖图形界面、命令行、注册表、批处理脚本及专业工具五种方法,适用于不同技术水平用户,帮助准确识别VC++各版本(如2010、2013、2015-2022)及系统架构(x86/x64),确保软件兼容性。
835 12
|
Kubernetes 负载均衡 调度
在k8S中,Pod的常见调度方式有哪些?
在k8S中,Pod的常见调度方式有哪些?
|
11月前
|
网络协议 Linux Android开发
深入探索Android系统架构与性能优化
本文旨在为读者提供一个全面的视角,以理解Android系统的架构及其关键组件。我们将探讨Android的发展历程、核心特性以及如何通过有效的策略来提升应用的性能和用户体验。本文不包含常规的技术细节,而是聚焦于系统架构层面的深入分析,以及针对开发者的实际优化建议。
336 21
|
存储 消息中间件 JSON
DDD基础教程:一文带你读懂DDD分层架构
DDD基础教程:一文带你读懂DDD分层架构
|
消息中间件 存储 安全
01为什么需要MQ及其好处
01为什么需要MQ及其好处
236 0
|
Java 测试技术 API
Java 新手入门:Java单元测试利器,Mock详解
Java 新手入门:Java单元测试利器,Mock详解
863 1
|
监控 关系型数据库 MySQL
如何优化MySQL数据库的索引以提升性能?
如何优化MySQL数据库的索引以提升性能?
396 0
|
Java 测试技术 容器
mockito(模拟测试)框架基本使用指南
mockito(模拟测试)框架基本使用指南
2992 1
|
Java 测试技术 API
Java中灵活使用Mockito
Java中灵活使用Mockito
208 0
|
存储 SQL 缓存
收好这份武林秘籍,让你分库分表再无烦恼
互联网发展至今,各个公司企业的数据量都大幅增长,分库分表越来越多的被我们用到,那么我们应该如何针对我们自己的业务场景,对数据进行合理的划分,用最小的代价解决掉性能瓶颈。
483 0