缺少对 verify(mock) 的方法调用,但有一个吗?

kar*_*bar 5 java mockito jukito

介绍

我正在尝试进行一个测试,验证(使用 Mockito v1.9.5's )在执行 pass-through 之后调用接口中verify具有签名的方法,并且我遇到了一个我真的不明白的错误。deinit()BarFoo.deinit()

这是FooTest.java我正在尝试运行的:

@RunWith(JukitoRunner.class)
public class FooTest {
    @Inject
    private Foo foo;
    @Inject
    private Bar bar;

    public static class TestModule extends JukitoModule {
        @Override
        protected void configureTest() {
            bind(Foo.class).to(FooImpl.class);
            bind(Bar.class).to(BarImpl.class);
            bindSpy(BarImpl.class);
        }
    }

    @Test
    public void testDeinit() {
        foo.init(mock(Baz.class));
        foo.deinit();
        verify(bar).deinit();
    }

    @After
    public void validate() {
        validateMockitoUsage(); //line YY
    }
}
Run Code Online (Sandbox Code Playgroud)

运行此程序时,testDeinit()失败并出现以下错误:

org.mockito.exceptions.misusing.UnfinishedVerificationException:
Missing method call for verify(mock) here:
  -> at redacted.impl.BarImpl.deinit(BarImpl.java:XX)
  
Example of correct verification:
  verify(mock).doSomething()
  
Also, this error might show up because you verify either of: final/private/equals()/hashCode() methods. 
Those methods *cannot* be stubbed/verified. 

at redacted.impl.FooTest.validate(FooTest.java:YY)
at org.jukito.InjectedStatement.evaluate(InjectedStatement.java:96)
at org.jukito.InjectedAfterStatements.evaluate(InjectedAfterStatements.java:58)
at org.jukito.jukitoRunner.run(JukitoRunner.java:197)
Run Code Online (Sandbox Code Playgroud)

我无法从中提取很多有用的信息。看起来几乎好像错误抱怨可能 verify(bar).deinit()没有结束.deinit(),我可以删除该部分并得到相同的错误。错误消息中提供的示例尤其令人沮丧,因为它看起来与我对verify.

细节

这是我的BarImpl.java

public class BarImpl implements Bar {
    private final Qux qux;
    private final Quux quux;

    @Inject
    public BarImpl(final Qux qux, final Quux quux) {
        this.qux = qux;
        this.quux = quux;
    }

    @Override
    private final void init(Baz baz) {
        quux.init(this);
        qux.init();
    }

    @Override
    public final void deinit() {
        qux.deinit();  //line XX
    }
}
Run Code Online (Sandbox Code Playgroud)

我仍然不清楚qux.deinit()这里是如何导致失败的。这是我的FooImpl.java

class FooImpl implements Foo {
    private final Bar bar;

    @Inject
    public FooImpl(final Bar bar) {
        this.bar = bar;
    }

    @Override
    public void init(Baz baz) {
        bar.init(baz);
    }

    @Override
    public void deinit() {
        bar.deinit(); 
    }
}
Run Code Online (Sandbox Code Playgroud)

问题

是什么导致了 UnfinishedVerificationException 以及如何修复它?

我是 Mockito 新手,所以很可能我错过了一些基本的东西。如果我可以提供更多信息,请告诉我。抱歉,如果这个问题已经得到回答,并且我误解了这里的答案。

Nic*_*tto 6

其实你的问题出在错误消息中:

此外,由于您验证了以下任一方法,因此可能会出现此错误: final /private/equals()/hashCode() 方法。这些方法无法被存根/验证。

事实上,您尝试隐式验证对方法的调用BarImpl#deinitfinal并且Mockio不支持final方法模拟,如doc 中所述。final如果您想验证它,您需要从声明中删除关键字BarImpl#deinit或使用Powermock代替。