1

我是单元测试的新手,我有一个关于verifyMockito 中使用的方法的简单问题。这是我用于测试的类。

public class Foo{
int n = 0;
void addFoo(String a){
    if(a == "a")
    add(1);
}

protected void add(int num){
    n =1;
}

public int get(){
    return n;
}

}

这是我的单元测试。

public class FooTest {
@Mock Foo f;

@Test
public void test() {
    MockitoAnnotations.initMocks(this);
    f.addFoo("a");

    //Passes
    Mockito.verify(f).addFoo("a");

    //Fails
    Mockito.verify(f).add(1);
}

}

我得到一个

   Wanted but not invoked:
f.add(1);
-> at FooTest.test(FooTest.java:22)

However, there were other interactions with this mock:
-> at FooTest.test(FooTest.java:16)

例外。

你如何验证它add(int num)被称为?

4

1 回答 1

3

我想你误解了verify. 在您的测试中,Foo f是一个模拟对象-Foo的内部实现被忽略,只有您在其上记录的行为(使用when(f.someMethod().thenXXX)才会发生。

模拟和验证的重点是在忽略内部实现的同时测试交互。在此示例中,您可能会有另一个使用 Foo的类,并且您想测试它是否调用给定Foo实例的正确方法。

快速示例:

假设您有一个类使用Foo您在问题中提出的类:

public class FooUser {
    private Foo f;

    public void setFoo(Foo f) {
        this.f = f;
    }

    public Foo getFoo() {
        return f;
    }

    public void addToFoo(String string) {
        f.add(string);
    }
}

现在,您想要测试FooUser#addToFoo(String)确实调用了正确add(String)的方法Foo

@RunWith (MockitoJUnitRunner.class)
public class FooUserTest {
    @Mock Foo f;
    FooUser fUser;

    @Before
    public void init() {
        fUser = new FooUser();
        fUser.setFoo(f);
    }

    @Test
    public void test() {
        fUser.addToFoo("a");
        Mockito.verify(f).addFoo("a");
    }
于 2013-11-05T06:26:01.447 回答