2

我正在为特定方法编写一个junit测试。该方法包含对我使用 EasyMock 模拟的 DAO 类中的其他方法的调用。

我想断言这些 DAO 类方法之一被调用一次,这就是我假设 expectLastCall().once() 的用途。有问题的方法返回 void。

我目前通过的测试,我只是想确保我的逻辑是正确的,因为我之前没有使用过 EasyMock。我用这个问题作为参考:EasyMock 使用 void 方法的期望

所以,这里是代码:

    @Before
    public void setUp() throws Exception{
    this.fooService = new FooService();
    this.fooMock = createStrictMock(FooDAO.class);
    }

    @Test
    public void test_fooTest(){

    String arg1 = "arg1";
    String arg2 = "arg2";
    this.fooService.setFooDAO(fooMock);
    expect(this.fooMock.someMethod(arg1, arg2)).andReturn(something);
    fooMock.methodThatShouldBeCalledOnce(EasyMock.<Object>anyObject());
    EasyMock.expectLastCall().once();
    replay(this.fooMock);
    this.fooService.methodUnderTest(someArg, someArg2);
    verify(this.fooMock);

    }

我认为这样做是断言有一个对 methodThatShouldBeCalledOnce 的调用并且它只发生一次。我并不真正关心 someMethod 但如果没有被告知期待它,EasyMock 当然会抱怨。

谢谢!

4

2 回答 2

1

这在我看来是正确的。您可以通过删除对 void 方法的调用并验证测试是否失败,或者通过添加对 void 方法的第二次调用并查看测试是否也失败来轻松地自行检查。

于 2013-03-06T13:22:10.113 回答
1

如果您不关心某些方法,则应该创建一个不错的模拟。那么,确实没有必要调用expectLastCall。它是隐含的,但可以是一个很好的做法,可以让你很明显你在模拟一个方法。once() 也不需要,因为它是默认值。

因此,如果改写它,使用漂亮的米克,删除隐式调用,添加静态导入而不添加多余的“this”,你应该得到:

@Before
public void setUp() throws Exception{
   fooService = new FooService();
   fooMock = createNiceMock(FooDAO.class);
   fooService.setFooDAO(fooMock);
}

@Test
public void test_fooTest(){  
   fooMock.methodThatShouldBeCalledOnce(anyObject());

   replay(fooMock); // or replayAll() if you extend EasyMockSupport

   fooService.methodUnderTest(someArg, someArg2);
   verify(fooMock); // or verifyAll() if you extend EasyMockSupport
}
于 2013-03-11T21:11:47.420 回答