免费下载案例集|20+数字化领先企业人才培养实践经验 了解详情
写点什么

如何对时间和日期进行系统与验收测试

  • 2009-12-04
  • 本文字数:1014 字

    阅读完需:约 3 分钟

人们经常探讨如何对时间和日期进行单元测试,因为我们无法在测试用例中使用绝对时间,否则即便测试通过,那也仅仅是针对该具体的日期通过而已。解决该问题的标准方式是采取由大佬 Adam Sroka 提出的依赖注入:

要想对大量日期进行测试需要对其进行计算,但执行计算的方法绝不可以自己获取这些日期,无论日期是“now”、来自于数据库还是用户输入。我们应该在一个较高层次上获取日期并对其进行计算。

对于单元测试来说这是小菜一碟,但问题是我们在验收与系统测试中应该如何做呢? Andreas Ebbert-Karroum 对于该问题给出了 3 个解决方案:

  1. 在测试中,保证期望的结果也是取决于日期和时间的。
  2. 修改应用以保证其不会使用系统的当前时间而是使用时间服务,我们可以远程控制该服务以使用不同的时间而不是当前的系统时间
  3. 远程修改系统时间

xUnit Test Patterns 一书的作者 Gerard Meszaros 使用了第二种方式(又名 Virtual Clock Pattern):

我们在真实的时间服务上添加了一个抽象层(意思就是通过一个接口隐藏了对系统时间 API 的调用),然后在用测试脚本进行测试时替换掉该实现。默认情况下实现应该是可插拔的。 这么做的好处是可以确保每次运行时都能覆盖所有的测试情况,可用于测试时间的竞态条件( race conditions)。

来自 Software Development Coach George Dinwiddie 说单独的时间源可以避免一些微妙的问题,运行在多个机器上的系统会有多个系统时间,比如说一台机器上的系统时间和另一台机器上的数据库时间等等。

Ward Cunnigham 维基百科)采取了一种不同的方式:“在swim 框架中,测试用例运行了几周。我们使用了一个全局变量$now 来编写SQL,该表达式会在每次执行之前处理好时间问题,无论是小时、天还是周。这种方式对于SQL 的跟踪非常有效”。

来自 FitSharp 的开发者Mike Stockdale 指出这种方式支持相对日期的解析,比如today+2。 FitLibrary 的创建者 Rick Mugridge 说这种方式具有一个“一般意义上的日期生成 DSL”,它考虑到了不同时区中(具有不同的格式)相对日期的选择问题。我们可以在月末选择日期,也可以在周一选择。这种方式广泛应用在预约系统中,在这类系统中未来日期的选择是个重要的议题,因此测试必须要利用系统中已有的数据(以及日期)。而测试自动化架构师 Martin Gijsen 则使用 ANTLR 来解决该问题。

综上所述,Andreas 提出的前两种方案都得到了广泛的应用。你使用哪种方式呢,其优缺点又各是什么呢?

查看英文原文: System/Acceptance Testing with Time and Dates

2009-12-04 13:251620
用户头像

发布了 88 篇内容, 共 262.1 次阅读, 收获喜欢 8 次。

关注

评论

发布
暂无评论
发现更多内容

网安科班精选!爱荷华大学教授的网络安全零基础入门教程!

我再BUG界嘎嘎乱杀

网络安全 安全 网络协议 WEB安全 网安

做小程序生态有哪些优点?

Geek_2305a8

创新技术无用、无脑梭哈Meme:本轮加密牛市的价值体系崩塌?

区块链软件开发推广运营

dapp开发 区块链开发 链游开发 NFT开发 公链开发

海外社媒引流策略及云手机的应用

Ogcloud

云手机 海外云手机 跨境电商云手机 云手机群控 云手机推荐

在线小工具用得好,工资直接翻一倍

伤感汤姆布利柏

比特币破新高了,然后接下来空虚了

区块链项目一站式包装孵化

项目进度管理指南:9款顶尖项目进度计划平台

爱吃小舅的鱼

项目管理 项目进度管理 项目进度管理软件

云原生代表技术(1)-不可变基础设施

虚实的星空

File Juicer for Mac(Mac文件数据提取工具) v4.100中文注册版

Mac相关知识分享

简析漏洞生命周期管理的价值与关键要求

我再BUG界嘎嘎乱杀

网络安全 安全 漏洞 网安

Aiseesoft Video Repair for Mac(视频修复工具) v1.0.22激活版

Mac相关知识分享

怎样用云手机进行海外推广营销

Ogcloud

云手机 海外云手机 云手机群控 海外社媒营销 海外营销推广

大咖公开课 | 大模型场景讲解以及测试方法

测吧(北京)科技有限公司

测试

macOS Sequoia 15(Macos15系统) v15.0 Beta 4测试版本

Mac相关知识分享

施工项目必备:7款顶级管理系统深度评测

爱吃小舅的鱼

项目管理 项目进度管理 项目进度管理软件 施工项目管理

仓颉编程语言技术指南:嵌套函数、Lambda 表达式、闭包

EquatorCoco

Java JavaScript 前端

Meta SAM 2:实时分割图片和视频中对象;Apple Intelligence 首个开发者测试版发布丨 RTE 开发者日报

声网

Native Instruments Kontakt 7 for Mac(苹果专业音频采样器)激活版

Mac相关知识分享

springboot的轻量替代框架-Solon

源字节1号

开源

NFTScan 正式上线 ERC404 浏览器和 NFT API 数据服务

NFT Research

NFT\ NFTScan ERC404

Java代码实现七夕魔方照片墙

不在线第一只蜗牛

Java 代码

如何对时间和日期进行系统与验收测试_研发效能_Mark Levison_InfoQ精选文章