白盒测试实验报告
白盒测试实验报告

白盒测试实验报告引言近年来,软件行业发展迅速,软件质量成为软件企业必须关注的重点。
白盒测试是软件测试的一种重要手段。
本文将介绍一次白盒测试实验的过程和结果。
实验内容本次实验采用的测试对象是一款音乐播放器软件,我们将以白盒测试为手段,对音乐播放器软件进行测试,为构建一个健壮性好,功能稳定的音乐播放器软件做出我们的贡献。
实验过程1.需求分析阶段需求分析是基础性工作,是成功进行软件测试的重要基础。
我们首先分析音乐播放器软件的需求,划分出测试的模块和对应的测试用例。
在分析过程中,我们还同时制定了测试计划和测试执行。
2.设计阶段在设计阶段,我们将测试模块分成了多个部分,比如软件启动,音乐播放,音乐分类等等。
设计测试用例时,我们着重考虑了边界值测试用例,异常测试用例,特殊情况测试用例等,以提高测试的覆盖率。
3.实施阶段在实施阶段,我们严格按照测试计划与测试用例执行测试。
针对测试结果,我们每天在会上讨论,分析测试结果,确认产生的缺陷,并提出了解决方案。
我们还记录了测试用例执行过程、测试结果及其缺陷,以备后续参考。
4.缺陷整理与跟踪在检测和记录所有缺陷及其描述、报告和跟踪过程中,我们将测试结果分为三类:一类是重要的缺陷,需要开发人员立即修复;二类是次要的缺陷,将在下一周期处理;三类是需要处理的小错误,可以在后续的版本中修复。
实验结果通过测试,我们发现了多个问题,并对其进行了记录和反馈。
其中主要缺陷有以下几个方面:1.在平台正常工作过程中,应及时清理平台缓存,否则可能导致存储空间的不足,影响音乐播放体验。
2.在进行音频播放时,带缓存的音乐样本(即缓存层的音乐)的播放时,有时会造成截断现象。
3.当用户对相同音频文件进行不同时间的快进、快退操作时,应能保证允许的时间是在音频文件长度范围内的。
结论本次白盒测试实验中,我们收集并汇总了测试过程中遇到的问题,并及时反馈给开发人员。
我们还为软件企业的软件质量提升提供了一定的保障,以帮助企业提高其软件产品的健壮程度和可靠性。
白度测试实验报告

白度测试实验报告1. 引言本文旨在介绍白盒测试实验的设计、实施和结果分析,以评估软件系统的可靠性、安全性和稳定性。
2. 实验目的本次实验旨在通过白盒测试方法,对待测试的软件系统进行全面检查,以发现潜在的错误和漏洞,提高软件的质量。
3. 实验设计3.1 测试对象本次实验的测试对象是一个开源的电子商务网站系统,系统包含用户注册登录、商品浏览和购买等功能。
3.2 测试环境本次实验使用的测试环境如下:- 操作系统:Windows 10- 浏览器:Google Chrome- 开发工具:Visual Studio Code、Git、Postman3.3 测试用例设计本次实验设计了以下测试用例:1. 用户注册:测试用户注册功能是否正常,包括用户名密码长度限制、用户名唯一性等。
2. 用户登录:测试用户登录功能是否正常,包括用户名密码验证、登录状态维持等。
3. 商品浏览:测试用户能否正常浏览商品列表,包括商品信息的展示和跳转等。
4. 商品购买:测试用户能否成功购买商品,包括商品添加购物车、结算等。
3.4 测试方法本次实验采用了白盒测试方法,以代码的结构和逻辑为基础,设计和执行测试用例。
4. 实验步骤4.1 系统分析首先对待测试的软件系统进行分析,了解系统的功能和架构,确定测试的范围和重点。
4.2 测试用例编写根据分析结果,设计测试用例,以涵盖系统的各个功能模块,确保全面覆盖。
4.3 环境配置配置测试环境,包括安装必要的软件和工具,并设置好运行和调试环境。
4.4 测试用例执行按照设计好的测试用例一一执行,并记录测试过程中的关键信息,如输入数据、输出结果、日志等。
4.5 实验结果分析根据测试用例的执行结果,分析系统存在的缺陷和不足之处,提出修复建议和改进意见。
5. 实验结果与讨论经过实验测试,发现了系统的若干问题:1. 注册功能存在用户名唯一性验证缺陷,允许重复注册相同用户名。
2. 登录功能在密码错误时没有提示信息,用户无法正确得知错误原因。
白盒测试实验报告

白盒测试实验报告一、实验目的本次白盒测试实验的主要目的是深入理解白盒测试的基本原理和方法,通过对给定程序的分析和测试,掌握代码覆盖的评估标准,提高测试用例的设计能力,发现程序中的逻辑错误和潜在缺陷,从而保障软件的质量和可靠性。
二、实验环境本次实验使用的编程环境为具体编程环境名称,测试工具为具体测试工具名称。
三、实验内容1、被测试程序的功能描述被测试程序是一个简单的数学计算程序,用于实现两个整数的加法、减法、乘法和除法运算。
程序接收用户输入的两个整数,并根据用户选择的运算类型进行相应的计算,最后输出计算结果。
2、程序代码分析以下是被测试程序的部分关键代码:```pythondef add_numbers(num1, num2):return num1 + num2def subtract_numbers(num1, num2):return num1 num2def multiply_numbers(num1, num2):return num1 num2def divide_numbers(num1, num2):if num2!= 0:return num1 / num2else:return "除数不能为 0"```3、测试用例设计为了全面测试程序的功能,设计了以下测试用例:|测试用例编号|输入数据(num1, num2, 运算类型)|预期输出|||||| 1 |(5, 3, 'add')| 8 || 2 |(5, 3,'subtract')| 2 || 3 |(5, 3,'multiply')| 15 || 4 |(6, 2, 'divide')| 3 || 5 |(5, 0, 'divide')|除数不能为 0 |4、代码覆盖分析在执行测试用例的过程中,使用测试工具对代码的覆盖情况进行了分析。
结果显示,语句覆盖达到了 100%,但分支覆盖只达到了 80%。
软件测试实验报告白盒测试

软件测试与质量课程实验报告
实验3:白盒测试
掌握静态白盒测试方法及一般要求
掌握白盒测试用例的设计方法
掌握白盒测试基本测试方法:逻辑覆盖、路径测试。
语句覆盖输入数据路径预期输出1A=2,B=5,C=3,1239不能构成三角形2A=15,B=15,C=1512459等边三角形3A=15,B=15,C=13124679等腰三角形4A=23,B=24,C=25124689一般三角形
判定覆盖输入数据路径预期输出1A=2,B=3,C=5,1239不能构成三角形
语句覆
盖
编号输入数据覆盖语句
1array[8,9,10,11] key 101,2,3,8
2array[8,9,10,11] key 251,2,3,9
3array[8,9,10,11] key 81,2,3,6,7
4array[8,9,10,11] key 91,2,3,4,5
判定覆
盖
编号输入数据路径
1array[8,9,10,11] key 101-2-3-4-5-6-8-
2array[8,9,10,11] key 251-2-3-4-5-6-8--10-11-4-12
果
果
果
缺席:扣10分实验报告雷同:扣10分实验结果填写不完整:扣1 – 10分
其他情况:扣分<=5分总扣分不能大于10分。
白盒测试试验报告

实验二:白盒软件测试一、实验目的通过简单程序白盒测试,熟悉测试过程,对软件测试行程初步了解,并养成良好的测试习惯。
熟练掌握如何运用基路径测试方法进行测试用例设计,初步熟悉如何利用程序插装技术进行逻辑覆盖率分析。
二、实验内容背景:被测测试程序功能:计算被输入日期是星期几;程序定义:已知公元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> usingnamespacestd;intmain(){intx=1,year,month,day;while(x){1.inti,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){case1:total2=0;break;case2:total2=31;break;case3:total2=60;break;case4:total2=91;break;case5:total2=121;break;case6:total2=152;break;case7:total2=182;break;case8:total2=213;break;case9:total2=244;break;case10:total2=274;break;case11:total2=305;break;case12:total2=335;break;}}else{14.switch(month){case1:total2=0;break;case2:total2=31;break;case3:total2=59;break;case4:total2=90;break;case5:total2=120;break;case6:total2=151;break;case7:total2=181;break;case8:total2=212;break;case9:total2=243;break;case10:total2=273;break;case11:total2=304;break;case12:total2=334;break;}//在加上输入的日,求其总和可得到从公元1年1月1日到输入日期当天的总天数15.total=total1+total2+day;16.intweek;17.week=total%7;18.cout<<”您输入的日期是";19.switch(week){case0:cout<<"星期天"<<endl;break;case1:cout<<"星期一"<<endl;break;case2:cout<<"星期二"<<endl;break;case3:cout<<" 星期三"<<endl;break;case4:cout<<"星期四"<<endl;break;case5:cout<<"星期五"<<endl;break;case6:cout<<"星期六"<<endl;break;cout<<"**********退出程序请输入0,否则任一输入继续**********"<<endl;cin>>x;}2、测试用例设计1)控制流图12)环路复杂度计算由图可知,图中的环路有六条,故环路复杂度为六。
白盒测试实验报告三角形形状山东大学[5篇范例]
![白盒测试实验报告三角形形状山东大学[5篇范例]](https://img.taocdn.com/s3/m/a74fb13a7dd184254b35eefdc8d376eeaeaa17dc.png)
白盒测试实验报告三角形形状山东大学[5篇范例]第一篇:白盒测试实验报告三角形形状山东大学实验报告一、实验目的运用白盒测试中的条件覆盖和判定覆盖检查程序中内部动作或者运行是否符合规范,各部分内容是否按照规定正常运行。
二、实验内容 1 1、题目输入三角形的三条边,判断三角形的类型,并返回三角形的详细类型,同时判断游戏是否结束,如果为结束,可以继续进行测试。
代码如下::(被测函数为类类Trinagle 中的returnType)package 白盒测试;import java.util.Scanner;public class Triangle {/*** @赵得山*/public static void main(String[] args){String g=“y”;Scanner scan=new Scanner(System.in);while(g.equalsIgnoreCase(g)){System.out.println(“请输入三个数字:”);int[] num=new int[3];for(int i=0;i<3;i++)num[i]=scan.nextInt();//对三条边进行插入排序for(int i=2;i>=1;i--)for(int j=0;jif(num[j]>num[j+1]){int temp=num[j];num[j]=num[j+1];num[j+1]=temp;}}for(int i=0;i<3;i++)System.out.print(num[i]+“ ”+Math.pow(num[i], 2)+“”);System.out.println(returnType(num[0],num[1],num[2])); //是否继续输入测试数据System.out.println(“是否继续输入数据?y/n”);if(!scan.next().equals(“y”)){System.out.println(“测试结束!”);System.exit(0);}}}/*** 返回三角形的类型*/static String returnType(int a,int b,int c){String type=“";if(a+b<=c||b+c<=a||a+c<=b){System.out.println(”请重新输入测试数据“);type=”不是三角形“;}else if(a==b&&a==c){type=”等边三角形“;}else if(a==b||a==c||b==c){if(Math.pow(a, 2)+Math.pow(b, 2)==Math.pow(c, 2))type=”等腰直角三角形“;else if(Math.pow(a, 2)+Math.pow(b, 2)>Math.pow(c, 2))type=”等腰锐角三角形“;else if(Math.pow(a, 2)+Math.pow(b, 2)type=”等腰钝角三角形“;}else if(Math.pow(a, 2)+Math.pow(b, 2)==Math.pow(c, 2))type=”一般直角三角形“;else if(Math.pow(a, 2)+Math.pow(b, 2)type=”一般钝角三角形“;else if(Math.pow(a, 2)+Math.pow(b, 2)>Math.pow(c, 2))type=”一般锐角三角形";return type;} }2、测试用例设计1)程序流程图如下:开始请输入三条边 a、b、c a+b<=c||b+c<=a||a+c<=ba==b&&a==c TFFa==b||a==c||b==c FMath.pow(a,2)+Math.pow(b, 2)==Math.pow(c, 2)FMath.pow(a,2)+Math.pow(b, 2)>Math.pow(c, 2)FTMath.pow(a,2)+Math.pow(b, 2)Math.pow(c, 2)Math.pow(a,2)+Math.pow(b, 2)结束TTTFF1))判定覆盖测试用例及测试结果输入数据预期结果实际结果测试结果 a=1b=1c=5 不是三角形不是三角形正确 a=5b=5c=5 等边三角形等边三角形正确 a=1b=1c= 2等腰直角三角形等腰直角三角形正确 a=4b=4c=1 等腰锐角三角形等腰锐角三角形正确 a=3b=3c=5 等腰钝角三角形等腰钝角三角形正确 a=3b=4c=5 一般直角三角形一般直角三角形正确 a=3b=5c=6 一般钝角三角形一般钝角三角形正确 a=10b=11 c=12 一般锐角三角形一般锐角三角形正确注:已覆盖所有的判定,由于条件太多,所以这里未列出判定的路径,还请老师见谅..2))条件覆盖测试用例及测试结果输入数据预期结果实际结果测试结果 a=1b=1c=4 不是三角形不是三角形正确 a=1b=4c=1 不是三角形不是三角形正确 a=4b=1c=1 不是三角形不是三角形正确 a=1b=1c=1 等边三角形等边三角形正确 a= 2b=1c=1 等腰直角三角形等腰直角三角形正确 a=4b=4c=1 等腰锐角三角形等腰锐角三角形正确 a=3b=3c=5 等腰钝角三角形等腰钝角三角形正确 a=3b=4c=5 一般直角三角形一般直角三角形正确 a=3b=5c=6 一般钝角三角形一般钝角三角形正确 a=10b=11 c=12 一般锐角三角形一般锐角三角形正确注:已覆盖所有的条件,所有条件的真假都取了一次,由于条件太多,所以这里未列出判定的路径,还请老师见谅..三、总结与体会通过这次实验,我对于白盒测试有了更加深刻和直观的认识,因为代码是自己编写的,同时也重新锻炼了自己的动手编码能力。
白盒测试实验报告

白盒测试实验报告关于三角形问题的白盒测试实验报告一、实验目的1、能熟练应用功能性测试技术进行测试用例设计;2、对测试用例进行优化设计;二、实验内容1、题目内容描述针对实验一编写的源代码进行白盒测试。
要求绘制出程序的控制流图,采用逻辑覆盖和基路径方法设计测试用例。
执行测试用例,并分析测试结果。
可以使用C++Test对代码进行静态检查和动态测试。
2、测试用例的编写根据条件绘制程序流程图如下:由程序流程图得如下控制流图:采用逻辑覆盖设计测试用例并执行测试用例:(1)语句覆盖:(2)判定覆盖(3)条件覆盖:(4)判定-条件覆盖:(5)条件组合覆盖:(6)路径覆盖:基路径方法设计测试用例并执行测试用例:3、测试结果分析经过以上测试发现:程序无法结束,达不到预测结果。
其余均能正确执行达到预期结果。
4、实验思考通过本次试验,对C++test工具有了一定的认识,学会了一些基本的用法和操作,用该工具测出了一些代码规范的问题,能够分析测试结果了。
本实验用两种方法对程序进行测试,从中可看出,基路径测试比逻辑覆盖测试过程简单,但是没有逻辑覆盖测试的效果好。
所以,我觉得应该更加熟悉两种测试方法的特色,以便在以后的测试中能更快更准确的选择测试方法,快速测试,找到程序中的错误。
附录:程序代码#include "iostream.h"#include "stdio.h"void Judge(int m_num1,int m_num2,int m_num3){while(scanf("%d %d %d",&m_num1,&m_num2,&m_num3)! =EOF){if(!(m_num1+m_num2<=m_num3 || m_num1+m_num3<=m_num2 || m_num2+m_num3<=m_num1)) {if (m_num1==m_num2 && m_num1==m_num3)cout<<"等边三角形"<else if (m_num1==m_num2 || m_num1==m_num3 || m_num2==m_num3)cout<<"等腰三角形"<elsecout<<"一般三角形"<}else{cout<<"不是三角形"<}}}void main(){int a,b,c;Judge(a,b,c);}第二篇:黑盒测试实验报告 12000字黑盒测试实验报告一实验内容1、系统地学习和理解黑盒测试的基本概念、原理,掌握黑盒测试的基本技术和方法;2、对一个已知的程序进行测试。
白盒测试技术实验报告

白盒测试技术实验报告一、实验内容1、系统地学习和理解白盒测试的基本概念、原理,掌握白盒测试的基本技术和方法;2、举例进行白盒测试,使用语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖、路径覆盖进行测试。
3、通过试验和应用,要逐步提高和运用白盒测试技术解决实际测试问题的能力;4、完成实验并认真填写实验报告二、问题描述输入三个整数a、b、c,分别作为三角形的三条边,通过程序判断这三条边是否能构成三角形?如果能构成三角形,则判断三角形的类型(等边三角形、等腰三角形、一般三角形)。
要求输入三个整数a、b、c,必须满足以下条件:1≤a≤200;1≤b≤200;1≤c≤200。
请采用静态白盒测试方法和动态白盒测试方法设计测试用例。
三、代码说明(复制测试的主要代码并在每行程序代码前面标上行号)1.importjava.util.Scanner;2.public class abc{3.public static void main(String args[]){4.String str1=””;5.String str2=””;6.String str3=””;7.inta,b,c;8.Scanner input = new Scanner(System.in);9.System.out.printf(“请输入三角形的三条边,以空格换行:\n”);10.str1=input.next();11.str2=input.next();12.str3=input.next();13.if(str1.matches(“\\d+”)&& str2.matches(“\\d+”)14.&& str3.matches(“\\d+”)){15.a=Integer.parseInt(str1);16.b=Integer.parseInt(str2);17.c=Integer.parseInt(str3);18.if(a+b>c&&a+c>b&&b+C>a){19.if(a==b||a==c|b==c){20.if(b==c&&a==c)21.System.out.printf(“等边三角形\n”);22.else23.System.out.printf(“等腰三角形\n”);24.}else25.System.out.printf(“一般三角形\n”);26.}else{27.System.out.printf(“不构成三角形\n”);28.}29.}30.}五、白盒测试分析1.代码走读1.importjava.util.Scanner;2.public class abc{3.public static void main(String args[]){/*读取三条边*/4.String str1=””;5.String str2=””;6.String str3=””;7.inta,b,c;8.Scanner input = new Scanner(System.in);9.System.out.printf(“请输入三角形的三条边,以空格换行:\n”);10.str1=input.next();11.str2=input.next();12.str3=input.next();/*判断三条边是否构成三角形*/13.if(str1.matches(“\\d+”)&& str2.matches(“\\d+”)14.&& str3.matches(“\\d+”)){15.a=Integer.parseInt(str1);16.b=Integer.parseInt(str2);17.c=Integer.parseInt(str3);18.if(a+b>c&&a+c>b&&b+C>a){19.if(a==b||a==c|b==c){20.if(b==c&&a==c)21.System.out.printf(“等边三角形\n”);22.else23.System.out.printf(“等腰三角形\n”);24.}else25.System.out.printf(“一般三角形\n”);26.}else{27.System.out.printf(“不构成三角形\n”);28.}29.}else{30.System.out.printf(“请输入整型数字”);31.}32.}33.}2.静态结构分析(函数控制流图法)3. 对判定的测试(1)函数流程图(2)语句覆盖?判定翻盖?条件覆盖?条件组合覆盖?判定/条件覆盖?修正的判定/条件覆盖(选1-2种覆盖方法,并说明选取的理由)选择判断覆盖语句:选择理由:基于判定覆盖指标的测试因需覆盖到每一条执行边,生成的测试用例数量相对语句覆盖有所增加,且测试重点转向判定节点,因此一般来说具有更强的测试覆盖能力。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验报告一、实验目的1.熟练掌握如何运用基路径测试方法进行测试用例设计。
2.初步熟悉如何利用程序插装技术进行逻辑覆盖率分析。
二、实验内容1、题目前一日函数PreDate是NextDate的逆函数(代码实现见下),实现功能为:输入1800 年到2050 年之间的某个日期,函数返回这一天的前一天的日期。
(此处不考虑无效输入)请采用基路径方法对前一日函数进行测试用例设计,并利用程序插装技术对测试用例的判定覆盖率进行检查分析。
代码:(被测函数为PreDate)#include""typedef struct MyDate{int month;int day;int year;}MyDate;MyDate PreDate(MyDate date);int Leapyear(int year);void Print(MyDate date);MyDate PreDate(MyDate date)//输入日期有效性检查中其他模块实现,此处假设输入日期都是合法数据{yesterday;= ; // initialization= ;= ;days_month[13]={0,31,0,31,30,31,30,31,31,30,31,30,31};//初始化每月天数,其中2月不确定,初始化为0 >1)else{==1){} if==3){(Leapyear){}else{}}else{}}yesterday;}Leapyear(int year){((year%4==0&&year%100!=0) || (year%400==0))1;return 0;}void Print(MyDate date){("%d--%d--%d\n",,,;}2、测试用例设计1)控制流图2)环路复杂度计算由图可知,图中的环路有五条,故环路复杂度为五。
3)基本路径集设计基本路径集为:A.1、2、3、4、5、6、8、12、13、14、15、20、25B.1、2、3、4、5、6、8、12、16、17、20、25C.1、2、3、4、5、6、8、12、18、19、20、25D.1、2、3、4、5、6、8、9、10、11、20、25E.1、2、3、4、5、6、7、20、254)测试用例集设计测试用例集为:2000-1-2 2000-1-1 2000-3-11999-3-1 1980-5-13、插装后源程序清单与判定覆盖率分析结果(要求截取插装后程序运行界面)#include""typedef struct MyDate{int month;int day;int year;}MyDate;int a[6];MyDate PreDate(MyDate date);int Leapyear(int year);void Print(MyDate date);int count();MyDate PreDate(MyDate date)//输入日期有效性检查中其他模块实现,此处假设输入日期都是合法数据{MyDate yesterday;= ; // initialization= ;= ;int days_month[13]={0,31,0,31,30,31,30,31,31,30,31,30,31}; //初始化每月天数,其中2月不确定,初始化为0if>1){a[0]=count();=;}else{a[1]= count();if==1){a[2]= count();=;=12;=31;}else if==3){a[3]=count();if(Leapyear){a[4]=count();=2;=29;}else{a[5]=count();=2;=28;}}else{a[6]=count();=;=days_month[];}}return yesterday;}int Leapyear(int year){if((year%4==0&&year%100!=0) || (year%400==0)) return 1;else return 0;}void Print(MyDate date){printf("%d--%d--%d\n",,,;}int count(){return 1;}void DriverofPreDate(){int tcPassNum = 0;int tcFailNum = 0; // 存储通过和失败的测试用例总数FILE *pFpFrom=NULL;FILE *pFpTo=NULL;//----------- 打开数据文件,准备读取测试用例的数据-----------char *DataFileName="";pFpFrom=fopen(DataFileName,"r");if(!pFpFrom){printf("读取数据失败,返回\n");return; }//----------- 打开数据文件,准备记录测试用例执行结果-----------char *DataFileTestResultName="";pFpTo=fopen(DataFileTestResultName,"w");if(!pFpTo){printf("打开文件失败,返回\n");return; }fprintf(pFpTo,"----------对函数PreDate的单元测试结果------------\n");//----------- 执行测试用例,记录测试结果-----------int TCID = 0;int sum=0;MyDate date ; // 测试用例的输入MyDate expectedOut,actualOut; // 测试用例的预期、实际输出 printf("对函数PreDate展开单元测试\n");while(!feof(pFpFrom)){ // 不断读取每个测试用例的数据 fscanf(pFpFrom, "%d ", &TCID); // 读入测试用例的IDfscanf(pFpFrom, "%d %d %d", &,&,&; //读测试用例输入fscanf(pFpFrom,"%d %d %d", &,&,&; // 读入测试用例的预期输出actualOut = PreDate(date); // 执行测试用例printf( "测试用例%d: 输入%d,%d,%d, 预期输出%d,%d,%d,,实际输出%d,%d,%d, ", TCID, ,,,, ,,,,; // 输出测试用例的信息if( ==&&==&&=={// 若测试用例通过,则记录通过用例总数tcPassNum ++; printf( "通过\n" );fprintf(pFpTo,"测试用例%d:Pass",TCID); //将测试结果存入结果文件 }else{tcFailNum ++; printf( "失败\n" );fprintf(pFpTo,"测试用例%d:Fail",TCID); //将测试结果存入结果文件 }}//----------- 统计测试结果-----------for(int i=0;i<=6;i++){sum=sum+a[i];}printf("覆盖率=%d", sum*100/7);printf("%%\n");printf( "共执行%d 个测试用例,其中%d 个通过,%d 个失败\n", tcPassNum+tcFailNum, tcPassNum, tcFailNum );fprintf(pFpTo,"共执行%d 个测试用例,其中%d 个通过,%d 个失败\n",tcPassNum+tcFailNum, tcPassNum, tcFailNum );fclose(pFpFrom);fclose(pFpTo);}void main(){DriverofPreDate ( );// 调用测试驱动程序}……三、总结与体会实验中对于路径测试有了更深的理解,可以更好、更迅速的去划分路径,设计测试用例,只是对插桩技术不太理解,不知道怎样去较好的设计插桩用例,也不知道怎样去计算插桩测试的覆盖率,通过实验过程对其有了进一步的理解,可是感觉还有点模糊,课后好好复习!还有,就是插桩测试的结果和预期的结果有所差异,没找到错误所在,希望老师能指出。