在我的 DAO 层中,我通过调用存储过程来完成所有数据库工作。 我想知道是否有人成功使用 EasyMock 测试了他们的 DAO 层?
谢谢 达米安
最佳答案
我想说这是不可能的。无法断言(使用 EasyMock 或其他模拟框架)DAO 实际上调用了某个存储过程,也无法验证它做了什么等。
使用 DAO + EasyMock 唯一能做的就是模拟/ stub DAO,但是这样你就不会测试 DAO,而是测试作用于 DAO 的协作者(如果我们说的是 MVC,通常是某种 Controller ) )。
要进行 DAO/StoredProcedures 的集成测试,我建议 DBUnit :
- 将测试数据放入数据库(如果您使用的是 jUnit,请在 @Before 方法中执行此操作)
- 调用被测 DAO 方法
- 如果方法返回任何结果,请将其与 (1) 中的预期数据进行比较
- 如果方法执行了一些插入/更新,则调用“读取方法”并将结果与 (1) 进行比较
如果您的 DAO 提供 CRUD对于某些业务实体,您可以测试 DAO 的每个操作:
testLoad
- 从数据库加载并与 (1) 进行比较testInsert
- 将新实体插入数据库然后重新加载并比较testUpdate
- 修改现有实体,保存到数据库并重新加载/比较testDelete
- 从 (1) 中删除一些实体,然后尝试加载它并断言它失败(也可以检查是否没有其他内容被删除)
关于java - EasyMock 和 Ibatis,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5174235/