实验一:白盒软件测试
一、实验目的
通过简单程序白盒测试,熟悉测试过程,对软件测试行程初步了解,并养成良好的测试习惯。熟练掌握如何运用基路径测试方法进行测试用例设计,初步熟悉如何利用程序插装技术进行逻辑覆盖率分析。
二、实验内容
背景:
被测测试程序功能:计算被输入日期是星期几;
程序定义:已知公元1年1月1日是星期一,只要输入年月日,能自动回复当天是星期几;
测试环境:Windows vista、Dev C++;
说明:本次测试采用插桩测试法,由于程序简单,手动输入测试用例。
程序说明:
A程序思路:计算输入日期与公元1年1月1日所相差的天数,具体如下:总天数=公元1年到输入日期上一年年底天数+输入年份的1月到上月月底天数+输入日期的天数
B闰年满足条件(year%4==0)&&(year%100!=0)||(year%400==0)
(1)分析各种输入情况,结合程序输出结果,并给出详细测试用例;
(2)根据(1)所划分的等价类,进行边界值分析,并给出具体的测试用例;
(3)决策表测试法;
①列出输入变量month、 day、 year的有效等价类;(条件桩)
②分析程序的规格说明,给出问题规定的可能采取操作;(动作桩)
③画出决策表(简化);
④根据决策表,给出详细测试用例。
代码:(被测部分为while循环内部语句)
#include <iostream>
using namespace std;
int main()
{
int x=1,year, month, day;
while(x)
{
1.int i, num=0,total, total1, total2;
2.cout<<"请输入年份: ";
3.cin>>year;
4.cout<<"请输入月份: ";
5.cin>>month;
6.cout<<"请输入日期: ";
7.cin>>day;
//求得输入年份之前一年末的总天数
8.for(i=1; i<year; i++)
{
9.if((i%4==0)&&(i%100!=0)||(i%400==0))
10.num++;
}
11.total1 = 365*(year-num-1) + 366*num;
//求得输入年份的总天数
12.if((year%4==0)&&(year%100!=0)||(year%400==0))
{
//求得输入月份之前一月末的总天数
13.switch(month)
{
case 1:total2 = 0;break;
case 2:total2 = 31;break;
case 3:total2 = 60;break;
case 4:total2 = 91;break;
case 5:total2 = 121;break;
case 6:total2 = 152;break;
case 7:total2 = 182;break;
case 8:total2 = 213;break;
case 9:total2 = 244;break;
case 10:total2 = 274;break;
case 11:total2 = 305;break;
case 12:total2 = 335;break;
}
}
else
{
14.switch(month)
{
case 1:total2 = 0;break;
case 2:total2 = 31;break;
case 3:total2 = 59;break;
case 4:total2 = 90;break;
case 5:total2 = 120;break;
case 6:total2 = 151;break;
case 7:total2 = 181;break;
case 8:total2 = 212;break;
case 9:total2 = 243;break;
case 10:total2 = 273;break;
case 11:total2 = 304;break;
case 12:total2 = 334;break;
}
}
//在加上输入的日,求其总和可得到从公元1年1月1日到输入日期当天的总天数
15.total = total1 + total2 + day;
16.int week;
17. week = total % 7;
18.cout<<"您输入的日期是";
19.switch(week)
{
case 0:cout<<"星期天"<<endl;break;
case 1:cout<<"星期一"<<endl;break;
case 2:cout<<"星期二"<<endl;break;
case 3:cout<<"星期三"<<endl;break;
case 4:cout<<"星期四"<<endl;break;
case 5:cout<<"星期五"<<endl;break;
case 6:cout<<"星期六"<<endl;break;
}
cout<<"**********退出程序请输入0,否则任一输入继续**********"<<endl;
cin>>x;
}
}
2、测试用例设计
1)控制流图
2)环路复杂度计算
由图可知,图中的环路有六条,故环路复杂度为六。
3)基本路径集设计
基本路径集为:
A.1、2、3、4、5、6、7、8、11、12、14、15、16、17、18、19
B.1、2、3、4、5、6、7、8、9、11、12、14、15、16、17、18、19
C.1、2、3、4、5、6、7、8、9、10、11、12、13、15、16、17、18、19
D.1、2、3、4、5、6、7、8、9、10、11、12、14、15、16、17、18、19
注:由源程序代码可知,未走路径10则必定不通过路径13,故省去两条检测路径。
4)测试用例集设计
测试用例集为:
A路径:1-2-26 预期输出:星期一
B路径:2-2-2 预期输出:星期六
C路径:2010-11-16 预期输出:星期二
D路径:2008-8-6 预期输出:星期三
3、插桩后源程序清单与判定覆盖率分析结果
#include <iostream>
using namespace std;
int main()
{
int x=1,year, month, day;
int m1=0,m2=0,m3=0,m4=0,m=15,n=0,f=0;
while(x)
{
n++;
cout<<"=====请输入测试用例====="<<endl;
int i, num=0,total, total1, total2,qw;
cout<<"请输入年份: ";
cin>>year;
cout<<"请输入月份: ";
cin>>month;
cout<<"请输入日期: ";
cin>>day;
cout<<"请输入预期输出结果(星期一到星期天,对应输入1~7):";
cin>>qw;
cout<<"程序运行路径: 1->2->3->4->5->6->7->8";
for(i=1; i<year; i++)
{
if((i%4==0)&&(i%100!=0)||(i%400==0))
num++;
}
if(i>1)
{
cout<<"->9";
if(m1==0){m++;m1=1;}
}
if(num>0)
{
cout<<"->10";
if(m2==0){m++;m2=1;}
}
total1 = 365*(year-num-1) + 366*num;
cout<<"->11->12";
if((year%4==0)&&(year%100!=0)||(year%400==0))
{
cout<<"->13";if(m3==0){m++;m3=1;}
switch(month)
{
case 1:total2 = 0;break;
case 2:total2 = 31;break;
case 3:total2 = 60;break;
case 4:total2 = 91;break;
case 5:total2 = 121;break;
case 6:total2 = 152;break;
case 7:total2 = 182;break;
case 8:total2 = 213;break;
case 9:total2 = 244;break;
case 10:total2 = 274;break;
case 11:total2 = 305;break;
case 12:total2 = 335;break;
}
}
else
{
cout<<"->14";if(m4==0){m++;m4=1;}
switch(month)
{
case 1:total2 = 0;break;
case 2:total2 = 31;break;
case 3:total2 = 59;break;
case 4:total2 = 90;break;
case 5:total2 = 120;break;
case 6:total2 = 151;break;
case 7:total2 = 181;break;
case 8:total2 = 212;break;
case 9:total2 = 243;break;
case 10:total2 = 273;break;
case 11:total2 = 304;break;
case 12:total2 = 334;break;
}
}
cout<<"->15->16->17->18->19"<<endl;
total = total1 + total2 + day;
int week;
week = total % 7;
cout<<"-----该测试用例测试结果-----"<<endl;
cout<<endl;
cout<<"测试用例"<<n<<" : 输入"<<year<<"."<<month<<"."<<day<<", 预期输出为:";
switch(qw%7)
{
case 0:cout<<"星期天, ";break;
case 1:cout<<"星期一, ";break;
case 2:cout<<"星期二, ";break;
case 3:cout<<"星期三, ";break;
case 4:cout<<"星期四, ";break;
case 5:cout<<"星期五, ";break;
case 6:cout<<"星期六, ";break;
}
cout<<"实际输出为:";
switch(week)
{
case 0:cout<<"星期天, ";break;
case 1:cout<<"星期一, ";break;
case 2:cout<<"星期二, ";break;
case 3:cout<<"星期三, ";break;
case 4:cout<<"星期四, ";break;
case 5:cout<<"星期五, ";break;
case 6:cout<<"星期六, ";break;
}
if(week==qw%7) cout<<"成功!"<<endl;
else
{
cout<<"失败!"<<endl;
f++;
}
cout<<endl;
cout<<"=====本次测试用例测试已结束,退出测试请输入0,否则任一输入继续测试====="<<endl;
cin>>x;
}
cout<<"最终对main函数中while内循环语句单元测试结果统计:"<<endl;;
cout<<"共执行"<<n<<"个测试用例, 总的路径覆盖率:"<<m*100/19<<"%, 其中通过"<<n-f<<"个, 失败"<<f<<"个"<<endl;
}
测试截图见附录
三、总结与体会
实验中对于路径测试有了更深的理解,可以更好、更迅速的去划分路径,设计测试用例。通过实验,我对软件测试有了进一步的认识和学习,对白盒测试流程有了较清楚的了解,收获很多。
实验报告课程:软件测试实验项目:白盒测试用例设计与执行专业年级:计科07级姓名:**学号:***指导教师:实验时间:20**-6-…
实验一白盒软件测试一实验目的通过简单程序白盒测试熟悉测试过程对软件测试行程初步了解并养成良好的测试习惯熟练掌握如何运用基路径测试方…
关于三角形问题的白盒测试实验报告一实验目的1能熟练应用功能性测试技术进行测试用例设计2对测试用例进行优化设计二实验内容1题目内容描…
《软件测试技术》实验报告实验序号:03实验项目名称:使用基本路径覆盖法测试自动售货机程序附件:修改后的实现代码:packagete…
三角形判定1题目内容描述输入三条边进行三角形的判定2测试用例的编写测试用例参照三角形的组成规则编写根据两边之和大于第三边的规则编写…
测量学实习报告目录一、前言--------------------------------------------------2二…
一:实习的目的、任务、测区概况目的:实习是工程测量教学的重要组成部分,除验证课堂理论外,还是巩固和深化课堂所学知识的环节,更是培养…
黑龙江科技学院测量实习报告实习名称:《测量实习》专业班级:工程管理10-4班姓名学号:王朋飞01号小组组号:第五作业小组指导教师:…
测量实习总结班级:建工一班姓名:陈登科学号:20xx130220xx4组号:第五组测区选点一、测区位臵:贵阳职业技术学院二、选点要…
工程测量实习报告实习地点:起止日期:指导老师:专业:班级:组号:姓名:工程测量实习报告一.实习时间:。。。。。。。。。。二.实习地…
实验报告一、实验目的运用白盒测试中的条件覆盖和判定覆盖检查程序中内部动作或者运行是否符合规范,各部分内容是否按照规定正常运行。二、…