问题描述
我使用的是 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) 来阻止间谍.示例:
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);
就你而言,它类似于:
doReturn(resultsIWant).when(myClassSpy).method1();
这篇关于Mockito:试图监视方法是调用原始方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!