河北民族师范学院软件测试课程设计报告题目:NextDate函数姓名:班级:学号:指导老师:2014.10.9目录第1章软件测试的概念和设计要求 (2)1.1 测试目的 (2)1.2 测试选题 (2)1.3测试人员 (2)1.4测试方法 (2)1.5 测试资料及参考书 (3)1.6关于黑盒测试 (3)1.7 关于白盒测试 (3)1.8、黑盒测试与白盒测试的比较 (4)1.9 软件测试过程 (4)1.10数据整理 (5)第2章NextDate函数问题 (5)2.1NextDate函数的黑盒测试 (5)2.1.1.问题描述: (5)2.1.2.程序代码(开发环境:Windowsxp xp、java): (5)2.1.3.测试方法 (5)2.1.4.测试用例设计 (8)2-2NextDate函数的白盒测试 (14)2.2.1核心程序代码 (14)2.2.2程序流程图 (14)2.2.3 测试用例 (15)2.2.4程序控制流图 (17)设计心得与体会 (17)第1章软件测试的概念和设计要求1.1 测试目的1.练习和掌握软件测试管理的一般过程与步骤;2.掌握测试管理的人工过程和能够通过相关管理软件实现以下工作:a)配置软件资产信息、软件需求、软件模型和缺陷数据库;b)创建和管理多个测试组和用户;c)配置测试环境、编写详细测试计划、安排测试进度;d)设计测试脚本、测试用例;e)实施测试、执行测试和评估测试。
1.2 测试选题NextDate函数;1.3测试人员张@@:软件测试计划及相关资料的编写与收集。
李@@:对特定问题编写程序代码,并对其进行黑盒测试。
王@@:对特定问题编写程序代码,并对其进行白盒测试。
1.4测试方法对于选题,使用黑盒测试技术,测试内容包括等价类划分测试、边界值分析测试、决策表方法使用。
使用白盒测试技术,测试内容包括语句覆盖测试、分支覆盖测试、条件覆盖测试、分支/条件覆盖测试、条件组合覆盖测试及基本路径测试。
1.5 测试资料及参考书1.软件测试与维护基础教程,机械工业出版社,黄武2.软件测试技术基础教程,电子工业出版社,顾海花3.软件测试,清华大学出版社,周元哲1.6关于黑盒测试测试规划是基于产品的功能,目的是检查程序各个功能是否能够实现,并检查其中的功能错误,这种测试方法称为黑盒测试(Black-box Testing)方法。
黑盒测试又称为功能测试、数据驱动测试和基于规格说明的测试。
它是一种从用户观点出发的测试,一般被用来确认软件功能的正确性和可操作性。
黑盒测试的基本观点是:任何程序都可以看作是从输入定义域映射到输出值域的函数过程,被测程序被认为是一个打不开的黑盒子,黑盒中的内容(实现过程)完全不知道,只明确要做到什么。
黑盒测试主要根据规格说明书设计测试用例,并不涉及程序内部构造和内部特性,只依靠被测程序输入和输出之间的关系或程序的功能设计测试用例。
1.黑盒测试的特点:(1)黑盒测试与软件的具体实现过程无关,在软件实现的过程发生变化时,测试用例仍然可以使用。
(2)黑盒测试用例的设计可以和软件实现同时进行,这样能够压缩总的开发时间。
2.黑盒测试的具体技术方法:●边界值分析法●等价类划分法●因果图法●决策表法1.7 关于白盒测试测试规划基于产品的内部结构进行测试,检查内部操作是否按规定执行,软件各个部分功能是否得到充分使用,则这种测试方法称为白盒测试(White-box Testing)方法。
白盒测试又称为结构测试、逻辑驱动测试或基于程序的测试,一般用来分析程序的内部结构。
白盒测试将被测程序看作一个打开的盒子,测试者能够看到被测源程序,可以分析被测程序的内部结构,此时测试的焦点集中在根据其内部结构设计测试用例。
白盒测试要求是对某些程序的结构特性做到一定程度的覆盖,或者说这种测试是“基于覆盖率的测试”。
通常的程序结构覆盖有:●语句覆盖●判定覆盖●条件覆盖●判定/条件覆盖●路径覆盖1.8、黑盒测试与白盒测试的比较1.9 软件测试过程单元测试:针对每个单元的测试,以确保每个模块能正常工作为目标。
集成测试:对已测试过的模块进行组装,进行集成测试。
目的在于检验与软件设计相关的程序结构问题。
确认(有效性)测试:是检验所开发的软件能否满足所有功能和性能需求的最后手段。
系统测试:检验软件产品能否与系统的其他部分(比如,硬件、数据库及操作人员)协调工作。
验收(用户)测试:检验软件产品质量的最后一道工序。
主要突出用户的作用,同时软件开发人员也应有一定程度的参与。
1.10数据整理测试所得到的用例测试报告、BUG报告,需要进行反馈和最后的归档,归档的工作按照项目计划中所规定的内容进行,反馈的工作在测试项结束后,整理成测试总结报告后进行,具体的日期,在项目计划中有规定。
不同阶段的测试,都需要重复以上的步骤。
其他必要的数据整理的工作,由项目经理在进行过程中进行安排。
第2章NextDate函数问题2.1NextDate函数的黑盒测试2.1.1.问题描述:NextDate是一个有三个变量(月份、日期和年)的函数. 函数返回输入日期后面的那个日期. 变量月份、日期和年都具有整数值,且满足以下条件:c1. l≤月份≤12c2. 1≤日期≤31c3. 1812≤年≤20122.1.2.程序代码(开发环境:Windowsxp xp、c语言):#include"stdafx.h"#include <iostream>using namespace std;void NextDate(int year,int month,int day);void main(){int year=0,month=0,day=0;NextDate(year,month,day);}void NextDate(int year,int month,int day){cout<<"请输入年份:"<<endl;cin>>year;while(!(year>=1911 && year<=2013)){cout<<"年份超过界限,请重新输入"<<endl;cin>>year;}cout<<"请输入月份:"<<endl;cin>>month;while (month>12||month<1){cout<<"月份输入有误,请重新输入"<<endl;cin>>month;}cout<<"请输入日期:"<<endl;cin>>day;while (day>31||day<1){cout<<"日期输入有误,请重新输入"<<endl;cin>>day;}while(month==4&&day==31||month==6&&day==31||month==9&&day==31||month==11&&day ==31){cout<<"小月没有31号"<<endl;cin>>day;} if((year%4==0 && year%100!=0) || (year%400==0)) //检查闰年;{int i=0;i=day-29;while(month==2&&i>0){cout<<"本月是闰月,请在1-29之间从新输入日期"<<endl;cin>>day;}if(month==2&&day==29){month=3;day=1;}else day++;}else day++;//月底计算;switch(month){case 1:case 3:case 5:case 7:case 8:case 10:if (day==32){month++;day=1;cout<<"明天是:"<<year<<'/'<<month<<'/'<<day<<endl;}break;case 2:if(day==29){month=3;day=1;cout<<"明天是:"<<year<<'/'<<month<<'/'<<day<<endl;}break;case 4:case 6:case 9:case 11:if(day==31){month++;day=1;cout<<"明天是:"<<year<<'/'<<month<<'/'<<day<<endl;}break;case 12:if(day==32){year++;month=1;day=1;cout<<"明天是:"<<year<<'/'<<month<<'/'<<day<<endl;}break;}cout<<"明天是:"<<year<<'/'<<month<<'/'<<day<<endl;}2.1.3.测试方法黑盒测试(等价类划分+边界值分析+决策表方法)2.1.4.测试用例设计输入条件编号有效等价类编号无效等价类输入年份⑴1912<=年<=2012 ⑺年<1912⑻年>2012输入月份⑵1<=月份<=12 ⑼月<1⑽月>12输入日期⑶1<=日期<=31 ⑾日期<1⑿日期>31输入类型⑷输入为int型⒀除int型外的任意输入输入为闰年⑸输入2月29日⒁输入为闰年2月30日输入为平年⑹输入2月28日⒂输入2月29日测试执行情况与记录测试用例编号输入预期结果实际输出覆盖等价类1 1988/2/3 1988/2/4 1988/2/4 ⑴⑵⑶⑷2 2000/2/29 2000/3/1 2000/3/1 ⑸3 2001/2/28 2001/3/1 2001/3/1 ⑹4 1800/1/23 年份输入有误,请重新输入年份输入有误,请重新输入⑺5 2200/3/2 年份输入有误,请重新输入年份输入有误,请重新输入⑻6 1912/0/3 月份输入有误,请重新输入月份输入有误,请重新输入⑼7 1927/30/3 月份输入有误,请重新输入月份输入有误,请重新输入⑽8 1956/3/-20 日期输入有误,请重新输入日期输入有误,请重新输入⑾9 1972/3/43 日期输入有误,请重新输入日期输入有误,请重新输入⑿10 asd 程序进入死循环程序进入死循环⒀11 2000/2/30 本月是闰月,请在1-29之间本月是闰月,请在1-29之间从新输入日期⒁从新输入日期12 2001/2/29 2001/2/30 2001/2/30 ⒂2.边界值分析方法用例月份日期年预期输出实际输出1 6 15 1911 6/16/1911 6/16/19112 6 15 1912 6/16/1912 6/16/19123 6 15 1962 6/16/1962 6/16/19624 6 15 2012 6/16/2012 6/16/20125 6 15 2013 6/16/2013 6/16/20136 6 1 1962 6/2/1962 6/2/19627 6 2 1962 6/3/1962 6/3/19628 6 15 1962 6/16/1962 6/16/19629 6 30 1962 7/1/1962 7/1/196210 6 31 1962 非法输入非法输入11 1 15 1962 1/16/1962 1/16/196212 2 15 1962 2/16/1962 2/16/196213 6 15 1962 6/16/1962 6/16/196214 11 15 1962 11/16/1962 11/16/196215 12 15 1962 12/16/1962 12/16/1962 3.决策表方法(1)month、day、year的有效等价类:M1:{month:month有30天}M2:{month:month有31天,12月除外}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不是闰年}(2)根据各种有效的输入情况,程序中可能采取的操作有以下六种:a1:不可能 a2:day 加1 a3:day 复位 1~3456~91011~1415条件: c1:month 在 c2:day 在 c3:year 在 M1 D1~D3 –M1 D4 –M1 D5 –M2 D1~D4 –M2 D5 –M3 D1~D4 –M3 D5 –动作: a1:不可能 a2:day 加1 a3:day 复位 a4:month 加1 a5;month 复位 a6:year 加1 √√ √√√√ √√√ √ √161718192021~22条件: c1:month 在 c2:day 在 c3:year 在 M4 D1 –M4 D2 Y1M4 D2 Y2M4 D3 Y1M4 D3 Y2M4 D4~D5 –动作: a1:不可能 a2:day 加1 a3:day 复位 a4:month 加1 a5;month 复位 a6:year 加1√√√ √√ √√√测试用例 Month Day Year 预期输出 1~3916200117/9/2001规则选项 规则选项4 9 30 2004 1/10/20045 9 31 2001 不可能6~9 1 16 2004 17/1/200410 1 31 2001 1/2/200111~14 12 16 2004 17/12/200415 12 31 2001 1/1/200216 2 16 2004 17/2/200417 2 28 2004 29/2/200418 2 28 2001 1/3/200119 2 29 2004 1/3/200420 2 29 2001 不可能21~22 2 30 2004 不可能 2-2求最大公约数和最小公倍数的白盒测试2.2.1核心程序代码if(n1<n2)//使得n1为较大的数,n2为较小的数{temp=n1;n1=n2;n2=temp;}p=n1*n2;//p为两个数的乘积while(n2!=0)//求两个数的最大公约数{r=n1%n2;n1=n2;n2=r;}2.2.2程序流程图2.2.3 测试用例输入期望输出执行路径测试结果Case1 n1=10n2=25最大公约数:5最小公倍数:50acdegf 最大公约数:5最小公倍数:50输入期望输出执行路径测试结果Case1 n1=5n2=4最大公约数:1最小公倍数:20abdegf 最大公约数:1最小公倍数:20Case2 n1=12n2=36最大公约数12最小公倍数:36acdegf 最大公约数:12最小公倍数:36输入期望输出执行路径测试结果Case1 n1=7n2=4最大公约数:1最小公倍数:28abdegf 最大公约数:1最小公倍数:28Case2 n1=4n2=8最大公约数:4最小公倍数:8acdef 最大公约数:4最小公倍数:8输入期望输出执行路径测试结果Case1n1=4n2=6最大公约数:2最小公倍数:12acdegf 最大公约数:2最小公倍数:12Case2 n1=7n2=5最大公约数:1最小公倍数:35abdegf 最大公约数:1最小公倍数:35输入执行路径执行路径测试结果Case1 n1=4n2=2最大公约数:2最小公倍数:4abdef 最大公约数:2最小公倍数:4Case2 n1=4n2=16最大公约数:4最小公倍数:16acdef 最大公约数:4最小公倍数:16Case3n1=9n2=4最大公约数:1最小公倍数:36abdegf 最大公约数:1最小公倍数:36Case4 n1=4n2=6 最大公约数:2最小公倍数:12acdegf 最大公约数:2最小公倍数:126.基本路径覆盖测试用例输入期望输出执行路径测试结果Case1n1=4n2=8最大公约数:4最小公倍数:8acdef 最大公约数:4最小公倍数:8Case2n1=80n2=14最大公约数:2最小公倍数:560abdegf 最大公约数:2最小公倍数:560Case3n1=20n2=10最大公约数:10最小公倍数:20abdef 最大公约数:10最小公倍数:20Case4 n1=12n2=15最大公约数:3最小公倍数:60acdegf最大公约数:3最小公倍数:60备注其他条件组合,无法到达结束2.2.4程序控制流图设计心得与体会本次测试中的压力测试是指模拟实际应用的软硬件环境及多用户订单提交过程的系统负荷,运行测试软件来测试被测系统的可靠性,同时还要测试被测系统的响应时间。