准备

在我们进一步讨论之前,让我们探索几种不同的方法来启用Mockito测试中注释的使用。

方式一 MockitoJUnitRunner

我们拥有的第一个选择是使用MockitoJUnitRunner注释JUnit测试,如以下示例所示:

@RunWith(MockitoJUnitRunner.class)
public class MockitoAnnotationTest {
...
}

方式二 MockitoAnnotations.initMocks()

另外,我们也可以通过调用MockitoAnnotations.initMocks()来以编程方式启用Mockito注释:

@Before
public void init() {
MockitoAnnotations.initMocks(this);
}

方式三 MockitoJUnit.rule()

或者,我们可以使用MockitoJUnit.rule(),如下所示:

public class MockitoInitWithMockitoJUnitRuleUnitTest {

    @Rule
public MockitoRule initRule = MockitoJUnit.rule(); ...
}

在这种情况下,我们必须记住将Rule成员设置为public。


Mockito注解介绍

@Mock Annotation

Mockito中使用最广泛的注释是@Mock。我们可以使用@Mock来创建和注入模拟实例,而不必手动调用Mockito.mock。

在下面的示例中–我们将使用手动方式创建模拟ArrayList,而不使用@Mock注释:

@Test
public void whenNotUseMockAnnotation_thenCorrect() {
List mockList = Mockito.mock(ArrayList.class); mockList.add("one");
Mockito.verify(mockList).add("one");
assertEquals(0, mockList.size()); Mockito.when(mockList.size()).thenReturn(100);
assertEquals(100, mockList.size());
}

现在我们将做同样的事情,但是我们将使用@Mock注释注入模拟:

@Mock
List<String> mockedList; @Test
public void whenUseMockAnnotation_thenMockIsInjected() {
mockedList.add("one");
Mockito.verify(mockedList).add("one");
assertEquals(0, mockedList.size()); Mockito.when(mockedList.size()).thenReturn(100);
assertEquals(100, mockedList.size());
}

请注意,在两个示例中,我们如何与模拟对象进行交互并验证其中的某些交互,只是为了确保模拟行为正确。

@Spy Annotation

现在–让我们看看如何使用@Spy注释监视现有实例。

在下面的示例中,我们使用旧方法创建一个列表的spy,而不使用@spy注释:

@Test
public void whenNotUseSpyAnnotation_thenCorrect() {
List<String> spyList = Mockito.spy(new ArrayList<String>()); spyList.add("one");
spyList.add("two"); Mockito.verify(spyList).add("one");
Mockito.verify(spyList).add("two"); assertEquals(2, spyList.size()); Mockito.doReturn(100).when(spyList).size();
assertEquals(100, spyList.size());
}

现在让我们做同样的事情–在列表上监视–但是使用@spy注释:

@Spy
List<String> spiedList = new ArrayList<String>(); @Test
public void whenUseSpyAnnotation_thenSpyIsInjectedCorrectly() {
spiedList.add("one");
spiedList.add("two"); Mockito.verify(spiedList).add("one");
Mockito.verify(spiedList).add("two"); assertEquals(2, spiedList.size()); Mockito.doReturn(100).when(spiedList).size();
assertEquals(100, spiedList.size());
}

请注意,像以前一样,我们在这里与间谍对象进行交互以确保其行为正确。在此示例中,我们:

  • 使用实际方法spiedList.add()将元素添加到spiedList。
  • 使用Mockito.doReturn()将spiedList.size()方法存根以返回100而不是2。

@Captor Annotation

接下来–让我们看看如何使用@Captor注释创建ArgumentCaptor实例。

在下面的示例中–我们使用旧方法创建ArgumentCaptor,而不使用@Captor注释:

@Test
public void whenNotUseCaptorAnnotation_thenCorrect() {
List mockList = Mockito.mock(List.class);
ArgumentCaptor<String> arg = ArgumentCaptor.forClass(String.class); mockList.add("one");
Mockito.verify(mockList).add(arg.capture()); assertEquals("one", arg.getValue());
}

现在,出于相同的目的,使用@Captor –创建一个ArgumentCaptor实例:

@Mock
List mockedList; @Captor
ArgumentCaptor argCaptor; @Test
public void whenUseCaptorAnnotation_thenTheSam() {
mockedList.add("one");
Mockito.verify(mockedList).add(argCaptor.capture()); assertEquals("one", argCaptor.getValue());
}

请注意,当我们取出配置逻辑时,测试如何变得更简单、更可读。

@InjectMocks Annotation

现在-让我们讨论如何使用@InjectMocks注释-将模拟字段自动注入到测试对象中。

在以下示例中,我们使用@InjectMocks将模拟wordMap注入MyDictionary dic:

@Mock
Map<String, String> wordMap; @InjectMocks
MyDictionary dic = new MyDictionary(); @Test
public void whenUseInjectMocksAnnotation_thenCorrect() {
Mockito.when(wordMap.get("aWord")).thenReturn("aMeaning"); assertEquals("aMeaning", dic.getMeaning("aWord"));
}

这是MyDictionary类:

public class MyDictionary {
Map<String, String> wordMap; public MyDictionary() {
wordMap = new HashMap<String, String>();
}
public void add(final String word, final String meaning) {
wordMap.put(word, meaning);
}
public String getMeaning(final String word) {
return wordMap.get(word);
}
}

Notes

最后–这是有关Mockito注释的一些说明:

  • Mockito的注释将重复的模拟创建代码减至最少
  • 它们使测试更具可读性
  • @InjectMocks支持同时注入@Spy和@Mock实例

在本快速教程中,我们展示了Mockito库中注释的基础。

注:本文翻译自原文:https://www.baeldung.com/mockito-annotations ,并且在此基础上有改动。

junit Mockito使用入门的更多相关文章

  1. JUnit + Mockito 单元测试(二)

    摘自: http://blog.csdn.net/zhangxin09/article/details/42422643 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] 入门 ...

  2. JUnit + Mockito 单元测试(二)(good)

    import org.junit.Test; import org.mockito.Matchers; import org.mockito.Mockito; import java.util.Lis ...

  3. JUnit + Mockito 单元测试

    原 JUnit + Mockito 单元测试(二) 2015年01月05日 17:26:02 sp42a 阅读数:60755 版权声明:本文为博主原创文章,未经博主允许不得转载. https://bl ...

  4. 基于Springboot+Junit+Mockito做单元测试

    前言 前面的两篇文章讨论过< 为什么要写单元测试,何时写,写多细 >和<单元测试规范>,这篇文章介绍如何使用Springboot+Junit+Mockito做单元测试,案例选取 ...

  5. Junit mockito 测试Controller层方法有Pageable异常

    1.问题 在使用MockMVC+Mockito模拟Service层返回的时候,当我们在Controller层中参数方法调用有Pageable对象的时候,我们会发现,我们没办法生成一个Pageable的 ...

  6. Junit mockito解耦合测试

    Mock测试是单元测试的重要方法之一. 1.相关网址 官网:http://mockito.org/ 项目源码:https://github.com/mockito/mockito api:http:/ ...

  7. Mockito框架入门教程(一)

    官网: http://mockito.org API文档:http://docs.mockito.googlecode.com/hg/org/mockito/Mockito.html 项目源码:htt ...

  8. JUnit+Mockito结合测试Spring MVC Controller

    [本文出自天外归云的博客园] 概要简述 利用JUnit结合Mockito,再加上spingframework自带的一些方法,就可以组合起来对Spring MVC中的Controller层进行测试. 在 ...

  9. Mock 模拟测试简介及 Mockito 使用入门

    Mock 是什么mock 测试就是在测试过程中,对于某些不容易构造或者不容易获取的对象,用一个虚拟的对象来创建以便测试的测试方法.这个虚拟的对象就是mock对象.mock对象就是真实对象在调试期间的代 ...

随机推荐

  1. 递归加法(day1)

    题目:求1+2+-+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字以及条件判断语句(A?B:C). 使用函数指针 1 2 3 4 5 6 7 8 9 10 ...

  2. kafka相关问题总结

    一直在使用kafka,遇到过很多问题,总结一下 很多人对比kafka和AMQP的时候,都会强调kafka会丢数据,感觉好像只要用kafka就会丢数据一样,从而排斥使用kafka,亦或者在使用的过程中, ...

  3. Mysql SQL Mode简介

    MySQL服务器能够工作在不同的SQL模式下,并能针对不同的客户端以不同的方式应用这些模式.这样,应用程序就能对服务器操作进行量身定制以满足自己的需求.这类模式定义了MySQL应支持的SQL语法,以及 ...

  4. date成字符串

    //获取当前时间 Date date=new Date(); System.out.println("当前date: "+date); //将时间转化成yyyy-MM-dd格式的字 ...

  5. Taro_Mall 是一款多端开源在线商城小程序.

    介绍 Taro_Mall是一款多端开源在线商城应用程序,后台是基于litemall基础上进行开发,前端采用Taro框架编写,现已全部完成小程序和h5移动端,后续会对APP,淘宝,头条,百度小程序进行适 ...

  6. Python 中的集合 --set

    前言 在Python中,我们用[]来表示列表list,用()来表示元组tuple,那{}呢?{}不光可用来定义字典dict,还可以用来表示集合set. 集合 set 集合(set)是一个无序的不重复元 ...

  7. 解决 Highcharts 中 yAxis 的 max 设置无效的问题

    问题场景 $(function () { Highcharts.chart('container', { title: { text: 'line' }, xAxis: { categories: [ ...

  8. [LeetCode] 1103. Distribute Candies to People 分糖果

    题目: 思路: 本题一开始的思路就是按照流程一步步分下去,算是暴力方法,在官方题解中有利用等差数列进行计算的 这里只记录一下自己的暴力解题方式 只考虑每次分配的糖果数,分配的糖果数为1,2,3,4,5 ...

  9. vue中的插槽(slot)

    vue中的插槽,指的是子组件中提供给父组件使用的一个占位符,用<slot></slot>标签表示,父组件可以在这个占位符中填充任何模板代码,比如HTML.组件等,填充的内容会替 ...

  10. 利用Java实现指定文件夹下的照片以自定义格式移动

    前几天本猿的大学同学,一个漂亮的小姐姐工作时遇到了一个问题,她的需求是,在公司局域网的电脑上下载大量的图片重命名成指定得1.2.3.....以此类推,需要当天完成,我就临时给写了一个小demo. 我的 ...