Mockito: Trying to spy on method is calling the original method(Mockito:试图监视方法正在调用原始方法)
问题描述
我正在使用 Mockito 1.9.0.我想在 JUnit 测试中模拟一个类的单个方法的行为,所以我有
I'm using Mockito 1.9.0. I want mock the behaviour for a single method of a class in a JUnit test, so I have
final MyClass myClassSpy = Mockito.spy(myInstance);
Mockito.when(myClassSpy.method1()).thenReturn(myResults);
问题是,在第二行中,myClassSpy.method1()
实际上被调用,导致异常.我使用模拟的唯一原因是以后,每当调用 myClassSpy.method1()
时,不会调用真正的方法,而 myResults
对象将是回.
The problem is, in the second line, myClassSpy.method1()
is actually getting called, resulting in an exception. The only reason I'm using mocks is so that later, whenever myClassSpy.method1()
is called, the real method won't be called and the myResults
object will be returned.
MyClass
是一个接口,而 myInstance
是一个实现,如果这很重要的话.
MyClass
is an interface and myInstance
is an implementation of that, if that matters.
我需要做些什么来纠正这种间谍行为?
What do I need to do to correct this spying behaviour?
推荐答案
让我引用 官方文档:
有时不可能使用 when(Object) 来存根间谍.示例:
Important gotcha on spying real objects!
Sometimes it's impossible to use when(Object) for stubbing spies. Example:
List list = new LinkedList();
List spy = spy(list);
// Impossible: real method is called so spy.get(0) throws IndexOutOfBoundsException (the list is yet empty)
when(spy.get(0)).thenReturn("foo");
// You have to use doReturn() for stubbing
doReturn("foo").when(spy).get(0);
在你的情况下,它是这样的:
In your case it goes something like:
doReturn(resultsIWant).when(myClassSpy).method1();
这篇关于Mockito:试图监视方法正在调用原始方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Mockito:试图监视方法正在调用原始方法


基础教程推荐
- 无法复制:“比较方法违反了它的一般约定!" 2022-01-01
- 使用堆栈算法进行括号/括号匹配 2022-01-01
- 问题http://apache.org/xml/features/xinclude测试日志4j 2 2022-01-01
- 存储 20 位数字的数据类型 2022-01-01
- Struts2 URL 无法访问 2022-01-01
- Spring AOP错误无法懒惰地为此建议构建thisJoinPoin 2022-09-13
- RabbitMQ:消息保持“未确认"; 2022-01-01
- 如何对 Java Hashmap 中的值求和 2022-01-01
- REST Web 服务返回 415 - 不支持的媒体类型 2022-01-01
- 修改 void 函数的输入参数,然后读取 2022-01-01