今天推荐的文章比较技术细节,谈到的是如何在单元测试过程中模拟日期或时间的变化所导致的业务处理逻辑。这个问题,初看起来比较简单,但是解决起来还是相对复杂。
本文的作者Jerrie Pelser最近遇到这样一个问题,需要定期检查用户订阅情况是否到期,并在到期前的一周、3天和1天内给用户发送提醒邮件。理所当然数据访问组件和邮件发送组件可以mock,那么日期和时间要如何处理呢?
作者简单介绍了几种可选的方式:
- 改变系统时钟。虽然很直接简单,但是并非是个好主意。作者对这种方式的坏处详细进行了解释。
- 传递当前时间。即修改方法签名,接受时间参数,以便在单元测试的时候传入所期望的时间。虽然有效,但是不够灵活。
- 创建一个时钟服务。基于上面的方法,定义一个时钟服务接口,正常运行就注入一个系统时钟,单元测试就Mock一个(使用NSubstitute作为mock框架)期望时间进去。
- 最终一种方式实际是使用一个函数库Noda Time。这个函数库实际上是实现了上面提到的方式,只是你可以直接使用了。
原文地址是:http://www.jerriepelser.com/blog/unit-testing-with-dates