夏令时(DST)测试

夏令时测试是比较小众的测试,主要针对在有夏令时的国家使用的软件,如果你接触到了这方面的测试,说明你在挣国外的钱:).

话不多说,先来介绍下什么是夏令时:

夏时制,夏时令(Daylight Saving Time:DST),又称“日光节约时制”和“夏令时间”,是一种为节约能源而人为规定地方时间的制度,在这一制度实行期间所采用的统一时间称为“夏令时间”。

我们所说的夏令时实际上包括两类:夏令时和冬令时

  • 夏令时(1:00 -> 3:00 AM)

    • 往后拨一个小时,直接从1点变到3点,也就是说我们要比原来提前一个小时和美国佬开会。
  • 冬令时(1:00 -> 1:00 -> 2:00 AM)
    • 往前拨一个小时,要过两个1点,这时比平常晚一个小时。

从这两种类型上看,我们的测试重点是放在有时间相关的操作上(时间显示、比较),以检测系统是否能够正确地运行。

下面我们来介绍夏令时测试需要关注的各个点:

  • 白盒测试

    • 代码走查以找出和时间操作相关的模块,进行合理的时间转换(本地时间转换为UTC时间)。这里需要关注的是和时间有关的部分,如果模块只和日期有关,可以忽略。
    • 并不是所有和时间有关的模块都要转换为UTC时间,这由业务决定(比如说打印log和界面时间显示,这时就需要用本地时间,而非UTC)
  • UI 测试

    • 时间输入:对于需要输入起始时间的控件,在夏令时当天需要注意对输入的检查,比如夏令时当天没有2:00AM。(对于冬令时,如果选择1:00 AM代表的是第一个一点)
    • 时间显示(输出): 产品时间的显示规则是与本地时间一致。对于需要显示时间段的部分,需要注意夏令时没有2:00AM,冬令时包含第二个1:00AM
    • 报表展示:首先大部分报表的数据都来源于数据库,而数据库一般保存的是UTC时间,所以需要转化成本地时间展示,这时在报表上可能出现的状况是:有些有起始时间的项的结束时间<开始时间,如果没有特别的要求,这种报表结果是可以接受的,但是要注意检查时间转换的准确性。
  • 数据存储

    • 文件的存储:这里分为日志和数据文件

      • 日志文件需要用本地时间存储,主要是问了方便查看。
      • 数据文件需要用UTC或者时间戳进行存储,防止造成数据不准确。
    • 数据库
      • 需要用UTC时间或者时间戳存储。
      • 进行查询操作,观察是否返回正确结果
      • 在夏令时转换点附近进行数据表的操作,检查数据时间显示(UTC或者时间戳)
      • 对于数据库中需要定期定时执行的任务,需要格外注意在夏令时当天的执行时间。
  • 功能性测试

    • 跨时间段任务

      • 常常会有一些任务会跨时间段,例如:一个Job计划执行的时间是2:00AM,在夏令时当天因为没有2:00AM,job会不会执行?或者是在冬令时的1:59AM执行,第二个1:00AM执行完毕,job会不会报错?以下时间段是需要我们在测试功能中需要特别关注的,以这些时间段作指导,执行用例,可以覆盖大部分场景。

      • 需要注意的点:
      1. 夏令时没有2:00AM
      2. 任务消耗时间区间需要特别注意,如果一个任务1:50执行到3:10,其实只用了20分钟,而不是1小时20分钟
      3. 冬令时有两个一点,预先计划好的任务中说的1:00AM,指的都是第一个1:00AM
      4. 冬令时有图中5中比较典型的时间段,需要特别注意。
  • 和其他模块的交互
    • 模块之间的交互需要遵循一致的规则,最好都能用UTC或者时间戳进行传输
    • 如果其他模块未遵循规则,需要对时间的传入和传出进行转换检查

总结:

DST测试的关注点更多的是夏令时、冬令时当天时间转换的处理逻辑,这就需要我们定义出来哪些时间段是容易出问题的,然后结合我们平时的用例,也会比较容易的把DST测试做好。

时间: 2024-07-31 11:05:27

夏令时(DST)测试的相关文章

夏令时 DST (Daylight Saving Time) java中的夏令时【转】

1916年,德国首先实行夏令时,英国因为怕德国会从中得到更大的效益,因此紧跟着也采取了夏令时 1986年至1991年,中华人民共和国在全国范围实行了六年夏令时 サマータイム 夏時間(日本现在没有实行夏令时,但是在美国驻军的1948年?1951年使用了夏令时) 一下内容来源:http://blog.csdn.net/java2000_net/article/details/4362316 =======================================================

InRange 测试像素的值是否在给定范围内

程序: 核心函数: cvInRange,cvInRangeS 代码: #include "cv.h" #include "cxcore.h" #include "highgui.h" #include <iostream> int InRangeS(int argc,char** argv) { IplImage *src=cvLoadImage("e:\\picture\\4.jpg"); IplImage *d

ntp时间同步,各种配置方法

1 Windows xp NTP服务器的配置(2003配置方式一样) 1) 首先需要关闭作为NTP服务器的windows系统自带的防火墙,否则将同步不成功. 2) 单击“开始”,单击“运行”,键入 regedit,然后单击“确定”. 找到下面的注册表项然后单击它: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\Config\ 在右窗格中,右键单击“AnnounceFlags”,然后单击“修改”. 在“编辑 DWORD 值

关于linux中的时间 时区问题

本文部分来源于:  http://hi.baidu.com/peruke/blog/item/b8de06ec6a04583b27979132.html 系统是fedora: glibc实现了从RTC时间到人可读时间的一个转换,一般系统不适用 环境变量TZ进行时区的设置,因为环境变量存在一些缺陷,在fedora中,系统是的时区设置为时区文件/etc/localtime,这个文件是一个/usr/share/zoneinfo/ 路径下面的时区文件的 软连接.时区文件的定义实在glibc的源码中就已经

Erlang日期与时间处理

在开发过程中,有两个概念是和地区区域相关的:字符编码和时间;编码和时间的规范演变过程中有文化的冲突有历史的遗留,是软件开发中充满人文气息的一角;关于字符编码我之前整理过一篇文章,[Erlang 0024]Erlang二进制数据处理 这部分知识很有意思,特别是格列佛游记所引出的大端小端概念,妙趣横生;平时笔记中也零零散散记录了一些和时间处理相关的内容,今天按图索骥把相关的资料整理汇集于此. 首先把时间相关的概念解释一下: 有关时间的概念 GMT时间 格林尼治标准时间(Greenwich Mean

SQL Server全时区转换

SQL Server全时区转换 假如你的应用程序是跨国(例如跨国银行交易)使用的话,那么数据库的一些国际化特性支持可以说是非常重要 其中最常见的就是各国时区上的差异,由于SQL Server getdate()读取的是本地机器所返回的值. 并不包含数据库时区位移,SQL Server2008新增了 datetimeoffset  数据类型(结合时区为基础的当日时间) 搭配SWITCHOFFSET 函数来更方便的处理时区转换问题 --时区转换 SELECT SYSDATETIMEOFFSET()

Python 3.5(常用模块)

常用模块: 模块介绍 time &datetime模块 random os sys shutil json & picle shelve xml处理 yaml处理 configparser hashlib subprocess logging模块 模块分为三种: 自定义模块 内置标准模块(又称标准库) 开源模块 #_*_coding:utf-8_*_ __author__ = 'Alex Li' import time # print(time.clock()) #返回处理器时间,3.3开

Linux基础命令---hwclock

hwclock   hwclock是一种访问硬件时钟的工具,可以显示当前时间,将硬件时钟设置为指定的时间,将硬件时钟设置为系统时间,以及从硬件时钟设置系统时间.您还可以定期运行hwlock以插入或删除硬件时钟中的时间,以补偿系统漂移(如果继续运行,则该时钟始终以一定的速率获得或丢失时间). 该命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.SUSE.openSUSE.Fedora. 1.语法 hwclock  [functions]  [options]   2.选项列表 下

juniper SRX防火墙NAT测试

1.测试拓扑: 2.测试总结: 3.基本配置: A.路由器R1: interface Ethernet0/0  ip address 202.100.1.1 255.255.255.0  no shut B.防火墙SRX: ①配置接口地址: set interfacesge-0/0/0.0family inetaddress 202.100.1.10/24 set interfacesge-0/0/1.0family inetaddress 10.1.1.10/24 set interfaces