aoe网java如何测试,java – 单元测试和太多的模拟

我开始在我的项目中练习TDD,作为背景,它还包含遗留代码.我们使用Mockito作为模拟框架并遵循

Spring MVC方法.

有些时候,使用许多不同的DAO对象实现了一个Service类作为@Autowired属性.这些服务中有简单的方法,例如completeTransaction.

completeTransaction将使用许多DAO对象来完成其职责

>更新并保存交易

>推进业务流程

>关闭其他待处理操作

但是,在执行这些操作时,该方法需要调用不同的DAO来获取和更新事务,获取业务流程ID,获取挂起的事务(并保存其更新).这意味着测试此方法的单元使我添加了许多@Mock属性.我需要在测试实际完成之前设置模拟对象以测试某个条件.

这看起来像代码味道,对我而言,几乎感觉测试是确保代码的实现而不仅仅是合同.同样,在不模仿依赖关系的情况下,测试用例将不会运行(由于NPE和其他因素).

我可以遵循什么策略来清理这样的代码? (虽然我无法真正提供问题的实际源代码).我认为一种可能性是使用类似(“getPendingOperations”和“advanceBusinessProcess”)的方法设置外观类.然后我可以模拟一个依赖.但后来我认为在所有其他具有这种情况的类中我需要做同样的事情,然后我害怕为了更清洁的测试而最终得到很多“辅助”类.

先谢谢你.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值