《软件测试新的》PPT课件.ppt
《《软件测试新的》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《软件测试新的》PPT课件.ppt(117页珍藏版)》请在三一办公上搜索。
1、请设计求解下列问题的算法,main()int i,j;float sum;sum=0.0;for(i=1;i=20;i+)for(j=1;j=3;j+)sum=sum+(i+1)*(i+1)*(j+2);printf(“sum=%dn”,sum);,内循环次数,20X4=80,外循环次数,21,总循环次数,101,main()int i,j;float sum;sum=0.0;for(j=1;j=3;j+)for(i=1;i=20;i+)sum=sum+(i+1)*(i+1)*(j+2);printf(“sum=%dn”,sum);,应把变化范围大的循环变量放在内层。,内循环次数,3X21=6
2、3,外循环次数,4,总循环次数,67,main()int i,j;float sum;sum=0.0;for(j=1;j=3;j+)for(i=1;i=20;i+)sum=sum+(i+1)*(i+1)*(j+2);printf(“sum=%dn”,sum);,j+2 共计执行了,3X20=60次,main()int i,j;float sum;sum=0.0;for(j=1;j=3;j+)k=j+2;for(i=1;i=20;i+)sum=sum+(i+1)*(i+1)*k;printf(“sum=%dn”,sum);,j+2 共计执行了,3次,减少了57次,应尽量把与循环变量无关的运算移到
3、循环外去。,main()int i,j;float sum;sum=0.0;for(j=1;j=3;j+)k=j+2;for(i=1;i=20;i+)sum=sum+(i+1)*(i+1)*k;printf(“sum=%dn”,sum);,i+1 共计执行了,60X60=120次,main()int i,j;float sum;sum=0.0;for(j=1;j=3;j+)k=j+2;for(i=1;i=20;i+)m=i+1;sum=sum+m*m*k;printf(“sum=%dn”,sum);,i+1 共计执行了,60次,第七章软件测试,7.1 软件测试的目的和原则7.2 软件测试方法7
4、.3 白盒测试的测试用例设计7.4 黑盒测试的测试用例设计7.5 软件测试策略7.6 软件测试的种类,在开发软件的过程中,我们使用了保证软件质量的方法分析、设计和实现软件,但难免还会在工作中 犯错误。这样,在软件产品中就会隐藏着许多错误和 缺陷。特别是对于规模大、复杂性高的软件更是如 此。在这些错误中,有些是致命性的错误如果不排除,就会导致生命与财产的重大损失。,DO 5 I=1,3,DO 5 I=1.3,1 美国航天,2 1999年 美国航天局的火星极地登陆飞船失踪,由于某一个数据位被意外的更改,3 金山词霸,软件测试是为了发现错误而执行程序的过程。或者 说,软件测试是根据软件开发各阶段的规
5、格说明和程序 内部结构而精心设计的一批测试用例(即输入数据及预 期的输出结果),并利用这些测试用例去运行程序,以发现程序错误的过程。,什么是软件测试,测试工具软件开发工程师(Software Development Engineer in Test,简称SDE/T),软件测试人员,软件测试工程师(Software Test Engineer,简称STE),SDE/T,负责写测试工具代码,并利用测试工具对软件进行测试;或者开发测试工具为软件测试工程师服务。,负责理解产品的功能要求,然后对其进行测试,检查软件有没有错误(Bug),决定软件是否具有稳定性,并写出相应的测试规范和测试案例。,STE,E
6、xchange 2000 和 Windows 2000 的人员结构,例如,,软件测试人员的任务很清楚,就是站在使用者的角度上,通过不断地使用和攻击刚开发出来的软件产品尽量多地找出产品存在的问题,也就是我们所称的 Bug。,7.1软件测试的基础,软件测试的目的软件测试的原则软件测试的对象测试信息流测试与软件开发各阶段的关系,7.1.1软件测试的目的,基于不同的立场,存在着两种完全不同的测试目的。从用户的角度出发,普遍希望通过软件测试暴露软件中隐藏的错误和缺陷,以考虑是否可接受该产品。从软件开发者的角度出发,则希望测试成为表明软件产品中不存在错误的过程,验证该软件已正确地实现了用户的要求,确立人们
7、对软件质量的信心。,Myers软件测试目的,(1)测试是程序的执行过程,目的在于发现错误;(2)一个好的测试用例在于能发现至今未发现的错误;(3)一个成功的测试是发现了至今未发现的错误的测试。,换言之,测试的目的是 想以最少的时间和人力,系统地找出软件中潜在的各种错误和缺陷。如果我们成功地实施了测试,我们就能够发现软件中的错误。测试的附带收获是,它能够证明软件的功能和性能与需求说明相符合。实施测试收集到的测试结果数据为可靠性分析提供了依据。测试不能表明软件中不存在错误,它只能说明软件中存在错误。,7.1.2软件测试的原则,1.应当把“尽早地和不断地进行软件测试”作为软件开发者的座右铭。2.测试
8、用例应由测试输入数据和对应的预期输出结果这两部分组成。3.程序员应避免检查自己的程序。一个很残酷的事情。“无情”4.在设计测试用例时,应当包括合理的输入条件和不合理的输入条件。,5.充分注意测试中的群集现象。经验表明,测试后程序中残存的错误数目与该程序中已发现的错误数目成正比。6.严格执行测试计划,排除测试的随意性。7.应当对每一个测试结果做全面检查。8.测试的真理:测试只能证明缺陷的存在,而不能证明缺陷的不存在。9.测试与质量的关系:测试有助于提高软件的质量,但是提高软件质量不能依赖于测试。,7.1.3 软件测试的对象,软件测试并不等于程序测试。软件测试应贯穿于软件定义与开发的整个期间。需求
9、分析、概要设计、详细设计以及程序编码等各阶段所得到的文档,包括需求规格说明、概要设计规格说明、详细设计规格说明以及源程序,都应成为软件测试的对象。,7.1.4测试信息流,建立可靠性模型,测试信息流,软件配置:软件需求规格说明、软件设计规格说明、源代码等;测试配置:测试计划、测试用例、测试程序等;测试工具:测试数据自动生成程序、静态分析程序、动态分析程序、测试结果分析程序、以及驱动测试的测试数据库等等。,测试结果分析:比较实测结果与预期结果,评价错误是否发生。排错(调试):对已经发现的错误进行错误定位和确定出错性质,并改正这些错误,同时修改相关的文档。修正后的文档再测试:直到通过测试为止。,通过
10、收集和分析测试结果数据,对软件建立可靠性模型利用可靠性分析,评价软件质量:软件的质量和可靠性达到可以接受的程度;所做的测试不足以发现严重的错误;如果测试发现不了错误,可以肯定,测试配置考虑得不够细致充分,错误仍然潜伏在软件中。,7.1.5测试与软件开发各阶段的关系,软件开发过程是一个自顶向下,逐步细化的过程软件计划阶段定义软件作用域软件需求分析建立软件信息域、功能和性能需求、约束等软件设计:编码阶段:把设计用某种程序设计语言转换成程序代码,测试过程是依相反顺序安排的自底向上,逐步集成的过程。,7.2 软件测试方法,两种常用的测试方法 黑盒测试 白盒测试,软件的测试设计与软件产品的设计一样,是一
11、项需要 花费许多人力和时间的工作,我们希望以最少量的时间和 人力,最大可能地发现最多的错误。,7.2.1黑盒测试,这种方法是把测试对象看做一个黑盒子,测试人员完全不考虑程序内部的逻辑结构和内部特性,只依据程序的需求规格说明书,检查程序的功能是否符合它的功能说明。黑盒测试又叫做功能测试或数据驱动测试。,黑盒测试方法是在程序接口上进行测试,主要是为了发现以下错误:是否有不正确或遗漏了的功能?在接口上,输入能否正确地接受?能否输出正确的结果?是否有数据结构错误或外部信息(例如数据文件)访问错误?性能上是否能够满足要求?是否有初始化或终止性错误?,用黑盒测试发现程序中的错误,必须在所有可能的输入条件和
12、输出条件中确定测试数据,来检查程序是否都能产生正确的输出。但这是不可能的。,假设一个程序P有输入量X和Y及输出量Z。在字长为32位的计算机上运行。若X、Y取整数,按黑盒方法进行穷举测试:可能采用的 测试数据组:232232 264 如果测试一 组数据需要1毫秒,一年工作365 24小时,完成所有测试需5亿年。,黑盒测试的内容,7.2.2 白盒测试,此方法把测试对象看做一个透明的盒子,它允许测试人员利用程序内部的逻辑结构及有关信息,设计或选择测试用例,对程序所有逻辑路径进行测试。通过在不同点检查程序的状态,确定实际的状态是否与预期的状态一致。因此白盒测试又称为结构测试或逻辑驱动测试。,软件人员使
13、用白盒测试方法,主要想对程序模块进行如下的检查:对程序模块的所有独立的执行路径至少测试一次;对所有的逻辑判定,取“真”与取“假”的两种情况都至少测试一次;在循环的边界和运行界限内执行循环体;测试内部数据结构的有效性,等。,对一个具有多重选择和循环嵌套的程序,不同的路径数目可能是天文数字。给出一个小程序的流程图,它包括了一个执行20次的循环。包含的不同执行路径数达520条,对每一条路径进行测试需要1毫秒,假定一年工作365 24小时,要想把所有路径测试完,需3170年。,7.3.1逻辑覆盖,7.3 白盒测试的测试用例设计,逻辑覆盖测试方法通常采用流程图来设计测试用例,它考察的重点是图中的判定框,
14、因为这些判定通常是与选择结构有关或是与循环结构有关,是决定程序结构的关键成分。,逻辑覆盖测试的5种标准,例,(1)语句覆盖,语句覆盖就是设计若干个测试用例,运行被测程序,使得每一可执行语句至少执行一次。在图例中,正好所有的可执行语句都在路径L1上,所以选择路径 L1设计测试用例,就可以覆盖所有的可执行语句。,b,d,a,输出的:A,B,X,c,e,输入的:A,B,X,2,0,4,2,0,3,满足语句覆盖的测试用例如下,a,c,e,-,-,ace(L1),abd(L2),abe(L3),acd(L4),L1,此方法发现不了判断中出现的逻辑运算中出现的错误。,(2)判定覆盖,判定覆盖就是设计若干个
15、测试用例,运行被测程序,使得程序中每个判断的取真分支和取假分支至少经历一次。判定覆盖又称为分支覆盖。对于图例,如果选择路径L1和L2,就可得满足要求的测试用例:,2,0,42,0,3,取“真”分支测试用例如下,a,c,e,-,-,a,b,d,-,-,1,1,11,1,1,取“假”分支测试用例如下,L1,L2,2,1,12,1,2,取“真假”分支测试用例如下,a,b,e,-,-,L3,如果选择路径L3和L4,还可得另一组可用的测试用例:,3,0,33,0,1,取“真假”分支测试用例如下,a,c,d,-,-,L4,X1 错写成 X1,(3)条件覆盖,条件覆盖就是设计若干个测试用例,运行被测程序,使
16、得程序中每个判断的每个条件的可能取值至少执行一次。在图例中,我们事先可对所有条件的取值加以标记。例如,对于第一个判断:条件 A1 取真为,取假为 条件 B0 取真为,取假为,对于第二个判断:条件A2 取真为,取假为 条件X1 取真为,取假为测试用例 覆盖分支 条件取值【(2,0,4),(2,0,3)】L1(c,e)【(1,0,1),(1,0,1)】L2(b,d)【(2,1,1),(2,1,2)】L3(b,e)或,请判断这组用例的判定覆盖,测 试 用 例覆盖分支 条件取值【(1,0,3),(1,0,4)】L3(b,e)【(2,1,1),(2,1,2)】L3(b,e),请判断这组用例的判定覆盖,第
17、二组仅仅覆盖了第一个判定的取假分支和第二个判定的取真分支,不能满足判定覆盖的要求!,(4)判定条件覆盖判定条件覆盖就是设计足够的测试用例,使得判断中每个条件的所有可能取值至少执行一次,同时每个判断中的每个条件的可能取值至少执行一次。,测 试 用 例覆盖分支 条件取值【(2,0,4),(2,0,3)】L1(c,e)【(1,1,1),(1,1,1)】L2(b,d),但是仍然有些逻辑表达式中的错误不能检查出来!因为:0*a=a 1+a=1 因此要把复合判定拆分!,and,or,(5)条件组合覆盖,条件组合覆盖就是设计足够的测试用例,运行被测程序,使得每个判断的所有可能的条件取值组合至少执行一次。记
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件测试新的 软件 测试 PPT 课件

链接地址:https://www.31ppt.com/p-5610151.html