IAm*_*aja 0 java junit mockito
我有一个非常简单的方法,我试图进行单元测试:
public class MyAntTask extends org.apache.tools.ant.Task {
public void execute() {
fire();
}
public void fire() {
// Do stuff
}
}
Run Code Online (Sandbox Code Playgroud)
我只想写一个单元测试,确认调用execute()
总是调用fire()
,所以我写了这个:
@Test
public void executeCallsFire() {
//GIVEN
MyAntTask myTask = Mockito.mock(MyAntTask.class);
// Configure the mock to throw an exception if the fire() method
// is called.
Mockito.doThrow(new RuntimeException("fired")).when(myTask).fire();
// WHEN
try {
// Execute the execute() method.
myTask.execute();
// We should never get here; HOWEVER this is the fail() that's
// being executed by JUnit and causing the test to fail.
Assert.fail();
}
catch(Exception exc) {
// THEN
// The fire() method should have been called.
if(!exc.getMessage().equals("fired"))
Assert.fail();
}
}
Run Code Online (Sandbox Code Playgroud)
我猜(我不是专家)Mockito通常不能模拟返回的方法void
,但这是一种解决方法.你基本上说"用一个Mock
将我的对象包装起来,RuntimeException
只要特定的方法即将被执行就会返回一个特定的对象".因此,fire()
Mockito 不是实际执行,而是看到它即将执行并抛出异常.执行验证?校验.
它没有通过,而是在Assert.fail()
调用之下的第一个失败myTask.execute()
.
对于我的生活,我无法弄清楚为什么.这是JUnit为失败提供的巨大堆栈跟踪的前10行左右:
java.lang.AssertionError
at org.junit.Assert.fail(Assert.java:92)
at org.junit.Assert.fail(Assert.java:100)
at net.myproj.ant.tasks.MyAntTaskUnitTest.executeCallsFire(MyAntTaskUnitTest.java:32)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:616)
Run Code Online (Sandbox Code Playgroud)
在这里有任何想法,你是StackOverflow的Mockito Gurus吗?提前致谢!
因为myTask是一个模拟,所以根本不调用真实对象.要调用真实对象,请使用间谍.
您可以测试使用verify调用方法,因此不需要异常.
public void executeCallsFire() {
MyAntTask myTask = Mockito.spy(new MyAntTask());
myTask.execute();
Mockito.verify(myTask).fire();
}
Run Code Online (Sandbox Code Playgroud)
想要模拟你正在测试的对象似乎并不正确.设计测试通常更好,这样您就可以验证对单独对象的调用.
归档时间: |
|
查看次数: |
1713 次 |
最近记录: |