如何使用mockito模拟void方法
如何用void返回类型来模拟方法?
我实现了观察者模式,但我不能用Mockito来嘲笑它,因为我不知道如何。
我试图在互联网上找到一个例子,但没有成功。
我的课堂看起来像
public class World {
List<Listener> listeners;
void addListener(Listener item) {
listeners.add(item);
}
void doAction(Action goal,Object obj) {
setState("i received");
goal.doAction(obj);
setState("i finished");
}
private string state;
//setter getter state
}
public class WorldTest implements Listener {
@Test public void word{
World w= mock(World.class);
w.addListener(this);
...
...
}
}
interface Listener {
void doAction();
}
系统不会被模拟触发。 =(我想显示上面提到的系统状态,并根据它们进行断言。
看看Mockito API文档。 正如链接文件提到的那样(第12点),您可以使用doThrow()
任何doThrow()
, doAnswer()
, doNothing()
, doReturn()
系列方法来模拟void方法。
例如,
Mockito.doThrow(new Exception()).when(instance).methodName();
或者如果您想将其与后续行为相结合,
Mockito.doThrow(new Exception()).doNothing().when(instance).methodName();
假设你正在寻找模拟setter setState(String s)
类的Setter setState(String s)
,下面的代码使用了doAnswer
方法来模拟setState
。
World mockWorld = mock(World.class);
doAnswer(new Answer<Void>() {
public Void answer(InvocationOnMock invocation) {
Object[] args = invocation.getArguments();
System.out.println("called with arguments: " + Arrays.toString(args));
return null;
}
}).when(mockWorld).setState(anyString());
我想我已经找到了一个更简单的答案来回答这个问题,为一个方法调用真正的方法(即使它有一个无效返回),你可以这样做:
Mockito.doCallRealMethod().when(<objectInstance>).<method>();
<objectInstance>.<method>();
或者,你可以为这个类的所有方法调用真正的方法,这样做:
<Object> <objectInstance> = mock(<Object>.class, Mockito.CALLS_REAL_METHODS);
除了@sateesh说的话,当你只是想嘲讽一个void方法以阻止测试调用它时,你可以这样使用一个Spy
:
World world = new World();
World spy = Mockito.spy(world);
Mockito.doNothing().when(spy).methodToMock();
当你想运行你的测试时,确保你调用spy
对象的测试方法,而不是world
对象。 例如:
assertEquals(0,spy.methodToTestThatShouldReturnZero());
链接地址: http://www.djcxy.com/p/27911.html