我遇到的问题是EasyMock为预期的(已定义的)方法调用返回null。
创建模拟对象
mock = EasyMock.createMock(DAO.class);
模拟在单元测试中设置。
expect(mock.update(myObj).andReturn(myObjUpdated).once();
replayAll();
service.setDao(mock);
service.processData(myObj);
verifyAll();
processData方法只需调用
MyObject objUpdated = dao.update(myObj);
这是构建模拟的接口。
public interface DAO {
public <ENTITY> ENTITY update(ENTITY entity);
}
我对可能导致问题的原因感到很困惑。我已经确认'obj'与我在单元测试中定义的对象相同。我也没有遇到任何其他模拟过的问题(我知道)。
问题可能出在传入的对象上吗?
提前致谢。我真的不确定其他哪些信息对您有帮助。
编辑:这是测试类(事实证明我的误解开始了)
public class TestMyService extends EasyMockHelper {...}
答案 0 :(得分:10)
事实证明,我的主要问题不在于期望,甚至不是模拟对象的创建。我对我的测试扩展功能的EasyMockSupport类有一个基本的误解。这在文档中没有很好地介绍,但是如果你仔细检查这些例子我的错误就变得很明显了。
EasyMockSupport类使我的测试类可以访问诸如replayAll(),verifyAll()和resetAll()之类的方法。这些操作让我现在担心手动控制每个创建的模拟对象。但是,文档没有提到的是你必须使用EasyMockSupport类提供的方法创建Mock对象,以便它可以正确地注册控件。 ((这使得总体感觉顺便说一句,我根本就没有在任何地方阅读它))。如果查看API,EasyMockSupport类为子类提供了它通常从EasyMock类中静态使用的所有方法,例如createMock(Class class)。
至于更新的代码
public class TestMyService extends EasyMockSupport {
private MyService service;
private MyDao dao;
private MyObject myObj;
@Before public void setUp() {
service = new MyService();
// THIS IS THE KEY
mock = createMock(IDao.class); //CORRECT
// mock = EasyMock.createMock(IDao.class); //WRONG
service.setDao(mock);
myObj = new MyObject("expectedData");
}
@After public void tearDown() {
verifyAll();
}
@Test public void testMyService() {
expect(mock.update(myObj)).andReturn(myObj);
replayAll();
service.myService(myObj);
}
}
public class MyService() {
private IDao dao;
public void setDao(IDao dao) {this.dao = dao; }
public MyObject myService(MyObject myObj) {
return dao.update(myObj);
}
}