我遇到了Mockito的问题。我有一个看起来像这样的课程:
public class Foo<T> {
BaseView mView;
public Foo(BaseView view) {
mView = view;
}
public void onResponse(T data) {
mView.setup(data);
}
public void onError(int error) {
mView.displayError(error);
}
}
好的,那我想做什么?
这是我想为Foo做的测试流程,
为BaseView
模拟Foo
。
如果已调用Foo onResponse
错误,则返回true。
如果已调用Foo onError
,则返回false。
这是我已经尝试过的:
public class BasePresenterCompatTest<T extends BasePresenterCompat> {
private Boolean setupCalled;
public void TestPresenterCall(BasePresenterCompat mPresenter) throws Exception {
Mockito.doAnswer(new TrueAnswer()).when(Mockito.mock(mPresenter.getClass())).onResponse(Mockito.any());
Mockito.doAnswer(new FalseAnswer()).when(Mockito.mock(mPresenter.getClass())).onError(Mockito.anyInt(), Mockito.anyString());
Assert.assertEquals(true, setupCalled);
}
class TrueAnswer implements Answer<Boolean> {
@Override
public Boolean answer(InvocationOnMock invocation) throws Throwable {
return setupCalled = true;
}
}
class FalseAnswer implements Answer<Boolean> {
@Override
public Boolean answer(InvocationOnMock invocation) throws Throwable {
return setupCalled = false;
}
}
}
Answer接口实现是一种好方法吗?因为我尝试调试测试并且它从未进入Answer类的答案方法,我缺少什么?
我忘了添加,我上面的方法得到的例外是:
Wanted but not invoked.
Actually, there were zero interactions with this mock.
答案 0 :(得分:1)
测试此方案的常用方法......
mPresenter是项目中名为BasePresenter的类的实例,它调用带有回调的Retrofit客户端,回调在&#34; onResponse&#34;中发送给此BasePresenter数据。方法或&#34; onError&#34;中的@StringRes整数。
...是模拟在verify上调用的回调,即对该模拟进行正确的调用。
例如:
@Test
public void testMockInvocation() {
BaseView baseView = Mockito.mock(BaseView.class);
Foo<String> foo = new Foo(baseView);
String input = "some input";
foo.onResponse(input);
Mockito.verify(baseView).setup(input);
int error = 1;
foo.onError(error);
Mockito.verify(baseView).displayError(error);
}
由于setup
和displayError
方法的类型为void
,因此无法返回任何内容,因此我怀疑此...
如果调用了Foo onResponse错误,则返回true。如果已调用Foo onError,则返回false。
...指的是关于您的测试如何证明/验证baseView
上调用了正确方法的想法。如果是这样,那么您可以使用Mockito.verify()
(如上例所示)来执行此操作。