软件测试 决策表
变量day加1操作;
变量day复位操作;
变量month加1操作;
变量month复位操作;
变量year加1操作。
根据上述动作桩发现NextDate函数得求解关键就是日与月得问题,通常可以在下面等价类(条件桩)得基础上建立决策表:
M1={month:month有30天}
M2={month:month有31天,12月除外}
{
k=1;
j++;
}
else if(j==12)
(1)1≤month≤12
(2)1≤day≤31
(3)1912≤year≤2050
2、实验目得与要求
分别输入测试用例,判断期望输出与实际输出就是否相等
3、实验环境
操作系统 WIN10
测试工具 VS2010
测试语言 c++语言
4、设计思路分析(包括需求分析、整体设计思路、概要设计)
需求分析:
此函数得主要特点就是输入变量之间得逻辑关系比较复杂。复杂性得来源有两个:一个就是输入域得复杂性,另一个就是指闰年得规则。例如变量year与变量month取不同得值,对应得变量day会有不同得取值范围,day值得范围可能就是1~30或1~31,也可能就是1~28或1~29。
决策表共有22条规则:
第1~5条规则解决有30天得月份;
第6~10条规则解决有31天得月份(除12月份以外);
第11~15条规则解决12月份;
第16~22条规则解决2月份与闰年得问题。
不可能规则也在决策表中列出,比如第5条规则中在有30天得月份中也考虑了31日。
表1输入变量间存在大量逻辑关系得NextDate函数决策表
√
√
√
√
A3: day复位
√
√
√
A4: month加1
√
√
A5: month复位
√
A6:year加1
√
表2简化得NextDate函数决策表:
选项
规则
1,
2,
3
4
5
6,
7,
8,
9
10
11,
12,
13,
14
15
16
17
18
19
20
21,
22
条件:
C1: month在
M1
M1
M1
M2
M2
M3
M3
M4
M4
M4
√
A6:year加1
√
6、实验结果与分析
表3 NextDate函数得测试用例组
测试用例
Month
Day
Year
预期输出
实际输出
Test case 1-3
5
15
2015
2015年5月16日
Test case 4
5
30
2015
2015年5月31日
Test case 5
5
31
2015
2015年6月1日
Test case 6-9
软件测试
实验报告
题目:决策表法得使用
学号:
姓名:
教师:
东南大学成贤学院电子与计算机工程学院
2017年 9 月30 日
方案30%
设计30%
文字表述20%
分析与总结20%
总分
实验题目
1、实验内容
NextDate函数包含三个变量:month(月份)、day(日期)与year(年),函数得输出为输入日期前一天得日期。例如,输入为2007年9月9日,则函数得输出为2007年9月10日。要求输入变量month、day与year均为整数值,并且满足下列条件:
附录代码
#include "stdafx、h"
bool NextDate(int i,int j,int k)
{
if(i>=1960&&i<=2050&&j>=1&&j<=12&&k>=1&&k<=31)
{
if(k>=1&&k<=27)
{k++;}
else
{
switch(k)
{
case 31:
{
if(j==1||j==3||j==5||j==7||j==8||j==10)
M3={month:month就是12月}
M4={month:month就是2月}
D1={day:1≤day≤27}
D2={day:day=28}
D3={day:day=29}
D4={day:day=30}
D5={day:day=31}
Y1={year:year就是闰年}
Y2={year:year不就是闰年}
整体设计思路:
NextDate函数中包含了定义域各个变量之间得依赖问题。等价类划分法与边界值分析法只能“独立地”选取各个输入值,不能体现出多个变量得依赖关系。决策表法则就是根据变量间得逻辑依赖关系设计测试输入数据,排除不可能得数据组合,很好地解决了定义域得依赖问题。
5、详细设计
NextDate函数求解给定某个日期得下一个日期得可能操作(动作桩)如下:
√
√
A5: month复位
规则
17
18
19
20
21
22
条件:
C1: month在
M3
M3
M3
M3
M4
M4
M4
M4
M4
M4
M4
C2: day在
D2
D3
D4
D5
D1
D2
D2
D3
D3
D4
D5
C3: year在
-
-
-
-
-
Y1
Y2
Y1
Y2
-
-
动作:
A1:不可能
√
√
√
A2: day加1
√
4
15
2015
2015年4月16日
Test case 10
4
31
2015
2015年5月1日
Test case11-14
12
15
2015
2015年12月16日
Test case 15
12
31
2015
2016年1月1日
Test case 16
2
15
2015
2015年2月16日
Test case 17
2
28
M4
M4
M4
C2: day在
D1,
D2,
D3
D4
D5
D1,
D2,
D3,
D4
D5
D1,
D2,
D3,
D4
D5
D1
D2
D2
D3
D3
D4,D5
C3: year在
-
-
-
-
-
-
-
-
Y1
Y2
Y1
Y2
-
动作:
A1:不可能
√
√
√
A2: day加1
√
√
√
√
√
A3: day复位
√
√
√
√
√
A4: month加1
√
√
√
√
A5: month复位
规则
选项
1
2
3
4
5
6
7
8
9
10
11
条件:
C1: month在
M1
M1
M1
M1
M1
M2
M2
M2
M2
M2
M3
C2: day在
D1
D2
D3
D4
D5
D1
D2
D3
D4
D5
D1
C3: year在
-
-
-
-
-
-
-
-
-
-
-
动作:
A1:不可能
√
A2: day加1
√
√
√
√
√
√
√
√
A3: day复位
√
√
A4: month加1
2016
2016年2月29日
Test case 18
2
28
2015
2015年3月1日
Test case 19
2
29
2016
2016年3月1日
Test case 20
2
29
2015
不可能!
Testcase 21-22
2
30
2015
不可能!
7、实验体会与建议
程序得实际输出结果与预期结果不符合,但基本满足实验问题需求,基于决策表得测试对于某些应用程序(例如NextDate函数)很有效,但就是对另外一些简单得应用程序就不值得使用决策表了。