【教学课件】第3章黑盒测试及其用例的设计.ppt
《【教学课件】第3章黑盒测试及其用例的设计.ppt》由会员分享,可在线阅读,更多相关《【教学课件】第3章黑盒测试及其用例的设计.ppt(81页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Slide 1第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计第第3章章 黑盒测试及其用例的设计黑盒测试及其用例的设计3.1 3.1 测试用例设计概述测试用例设计概述3.2 3.2 黑盒测试法的概念黑盒测试法的概念3.3 3.3 三角形问题与三角形问题与NextDateNextDate函数函数3.4 3.4 等价类划分法等价类划分法3.5 3.5 边界值分析法边界值分析法3.6 3.6 因果图法因果图法3.7 3.7 决策表法决策表法3.8 3.8 错误推测法错误推测法3.9 3.9 测试方法的选择测试方法的选择Slide 2第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计
2、本章教学目标本章教学目标理论环节理论环节理论环节理论环节n n学习理解黑盒测试方法的基本概念学习理解黑盒测试方法的基本概念n n学习理解黑盒测试的两个典型问题学习理解黑盒测试的两个典型问题n n学习掌握黑盒测试的等价类划分法学习掌握黑盒测试的等价类划分法n n学习掌握黑盒测试的边界值分析法学习掌握黑盒测试的边界值分析法n n学习掌握黑盒测试的因果图测试法和决策表法学习掌握黑盒测试的因果图测试法和决策表法实践环节实践环节实践环节实践环节n n通过案例运用学习掌握运用方法解决实际问题的能力通过案例运用学习掌握运用方法解决实际问题的能力n n运用等价类划分法与边界值分析法进行实际程序测试运用等价类划
3、分法与边界值分析法进行实际程序测试n n运用因果图测试法与决策表法进行实际程序测试运用因果图测试法与决策表法进行实际程序测试Slide 3第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计3.1 测试用例设计概述测试用例设计概述3.1.1 3.1.1 测试用例的定义和特征测试用例的定义和特征3.1.2 3.1.2 测试用例的基本准则测试用例的基本准则3.1.3 3.1.3 设计测试用例的着眼点设计测试用例的着眼点3.1.4 3.1.4 测试用例设计书写标准测试用例设计书写标准ReturnSlide 4第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计3.1.1 测试用例的定义和
4、特征测试用例的定义和特征n n测试用例的定义:测试用例的定义:(1 1)测测试试用用例例是是为为特特定定的的目目的的而而设设计计的的一一组组测测试试输输入入、执行条件和预期的结果。执行条件和预期的结果。(2 2)测试用例是执行的最小实体。)测试用例是执行的最小实体。n n测试用例的特征:测试用例的特征:(1 1)最有可能抓住错误的;)最有可能抓住错误的;(2 2)不是重复的、多余的;)不是重复的、多余的;(3 3)一组相似测试用例中最有效的;)一组相似测试用例中最有效的;(4 4)既不是太简单,也不是太复杂。)既不是太简单,也不是太复杂。Slide 5第三章第三章 黑盒测试及其用例的设计黑盒测
5、试及其用例的设计3.1.2 设计测试用例的基本准则设计测试用例的基本准则n n测试用例的代表性测试用例的代表性 能够代表并覆盖各种合理的和不合理的、合法的和非法能够代表并覆盖各种合理的和不合理的、合法的和非法的、边界的和越界的以及极限的输入数据、操作和环境的、边界的和越界的以及极限的输入数据、操作和环境设置等。设置等。n n测试结果的可判定性测试结果的可判定性 即测试执行结果的正确性是可判定的,每一个测试用例即测试执行结果的正确性是可判定的,每一个测试用例都应有相应的期望结果。都应有相应的期望结果。n n测试结果的可再现性测试结果的可再现性 即对同样的测试用例,系统的执行结果应当是相同的。即对
6、同样的测试用例,系统的执行结果应当是相同的。Slide 6第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计3.1.3 设计测试用例的着眼点设计测试用例的着眼点n n根据产品规格,测试基本功能;根据产品规格,测试基本功能;n n考虑设计一般用户(非专业人员)的使用方案;考虑设计一般用户(非专业人员)的使用方案;n n考虑设计稀有或特殊的使用方案;考虑设计稀有或特殊的使用方案;n n与与系系统统其其他他组组成成部部分分的的配配合合(如如FAXFAX和和上上网网可可能能要要用用到到MODEMMODEM,测试中考虑对设备的共享);,测试中考虑对设备的共享);n n考虑特殊情况(如内存和硬件的
7、冲突等);考虑特殊情况(如内存和硬件的冲突等);n n设计极端情况(如内存泄漏、破坏性测试等);设计极端情况(如内存泄漏、破坏性测试等);n n好的测试用例集能花费最小的代价(人力、物力、财力、好的测试用例集能花费最小的代价(人力、物力、财力、时间)做最好的测试。时间)做最好的测试。Slide 7第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计3.1.4 测试用例设计书写标准测试用例设计书写标准 在在ANSI/IEEE829-1983ANSI/IEEE829-1983标准中列出了和测试设计相关的标准中列出了和测试设计相关的测试用例编写规范和模板。标准模板中主要元素如下:测试用例编写规
8、范和模板。标准模板中主要元素如下:n n标识符标识符惟一标识每一个测试用例惟一标识每一个测试用例n n测试项测试项准确的描述所需要测试的项及其特征准确的描述所需要测试的项及其特征n n测试环境要求测试环境要求表征执行该测试用例需要的测试环境表征执行该测试用例需要的测试环境n n输入标准输入标准执行测试用例的输入需求(这些输入可能包执行测试用例的输入需求(这些输入可能包括数据、文件或者操作)括数据、文件或者操作)n n输出标准输出标准按照指定的环境和输入标准得到的期望输出按照指定的环境和输入标准得到的期望输出结果结果n n测试用例之间的关联测试用例之间的关联标识该测试用例与其它的测试标识该测试用
9、例与其它的测试(或其它测试用例)之间的依赖关系(或其它测试用例)之间的依赖关系范例范例1范例范例2Slide 8第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计 3.2 黑盒测试法的概念黑盒测试法的概念Returnn n黑盒测试被称为功能测试或数据驱动测试。在测试时,把被黑盒测试被称为功能测试或数据驱动测试。在测试时,把被测程序视为一个不能打开的黑盒子,在完全不考虑程序内部测程序视为一个不能打开的黑盒子,在完全不考虑程序内部结构和内部特性的情况下进行。结构和内部特性的情况下进行。n n采用黑盒测试的目的主要是在已知软件产品所应具有的功能采用黑盒测试的目的主要是在已知软件产品所应具有的
10、功能的基础上,进行:的基础上,进行:(1 1)检查程序功能能否按需求规格说明书的规定正常使用,)检查程序功能能否按需求规格说明书的规定正常使用,测试各个功能是否有遗漏,检测性能等特性要求是否满足。测试各个功能是否有遗漏,检测性能等特性要求是否满足。(2 2)检测人机交互是否错误,检测数据结构或外部数据库访)检测人机交互是否错误,检测数据结构或外部数据库访问是否错误,程序是否能适当地接收输入数据而产生正确的问是否错误,程序是否能适当地接收输入数据而产生正确的输出结果,并保持外部信息(如数据库或文件)的完整性。输出结果,并保持外部信息(如数据库或文件)的完整性。(3 3)检测程序初始化和终止方面的
11、错误。)检测程序初始化和终止方面的错误。Slide 9第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计3.3 三角形问题与三角形问题与NextDate函数函数 1 1、三角形问题、三角形问题 输入三个整数输入三个整数a a、b b、c c,分别作为三角形的三条边,现,分别作为三角形的三条边,现通过程序判断由三条边构成的三角形的类型为等边三角形、通过程序判断由三条边构成的三角形的类型为等边三角形、等腰三角形、一般三角形(特殊的还有直角三角形),以及等腰三角形、一般三角形(特殊的还有直角三角形),以及构不成三角形。构不成三角形。现在要求输入三个整数现在要求输入三个整数a a、b b、c
12、c,必须满足以下条件:,必须满足以下条件:条件条件1 1a100 1 1a100 条件条件4 ab+c4 ab+c 条件条件2 1b100 2 1b100 条件条件5 ba+c 5 ba+c 条件条件3 1c100 3 1c100 条件条件6 ca+b6 ca+b ReturnSlide 10第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计三角形问题与三角形问题与NextDate函数函数(续)(续)n n如果输入值如果输入值a a、b b、c c不满足条件不满足条件1 1、条件、条件2 2和条件和条件3 3,程序给,程序给出出“边的取值超出允许范围边的取值超出允许范围”的信息。的信息
13、。n n如果输入值如果输入值a a、b b、c c 满足条件满足条件1 1、条件、条件2 2和条件和条件3 3,则输出下,则输出下列四种情况之一:列四种情况之一:(1 1)如果不满足条件)如果不满足条件4 4、条件、条件5 5和条件和条件6 6中的一个,则程序输中的一个,则程序输出为出为“非三角形非三角形”。(2 2)如果三条边相等,则程序输出为)如果三条边相等,则程序输出为“等边三角形等边三角形”。(3 3)如果恰好有两条边相等,则程序输出为)如果恰好有两条边相等,则程序输出为“等腰三角形等腰三角形”。(4 4)如果三条边都不相等,则程序输出为)如果三条边都不相等,则程序输出为“一般三角形一
14、般三角形”。n n结论结论结论结论:三角形问题的复杂之处在于输入与输出之间的关系:三角形问题的复杂之处在于输入与输出之间的关系比较复杂。比较复杂。Slide 11第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计三角形问题与三角形问题与NextDate函数函数(续)(续)2 2、NextDateNextDate函数函数 NextDateNextDate函函数数说说明明另另一一种种复复杂杂的的关关系系,即即输输入入变变量量之之间间逻辑关系的复杂性。逻辑关系的复杂性。NextDate NextDate函数包含三个变量函数包含三个变量monthmonth、dayday和和yearyear,函
15、数的函数的输出为输入日期后一天的日期。输出为输入日期后一天的日期。要求输入变量要求输入变量monthmonth、dayday和和yearyear均为整数值,并且满足下列条件:均为整数值,并且满足下列条件:条件条件1 1 month 121 1 month 12 条件条件2 1 day 312 1 day 31 条件条件3 1912 year 20503 1912 year 2050n n结论:结论:结论:结论:在在NextDateNextDate函数中有两种复杂性的输入来源,一是输函数中有两种复杂性的输入来源,一是输入域的复杂性,二是确定闰年的规则并要增加入域的复杂性,二是确定闰年的规则并要增
16、加“额外天额外天”。Slide 12第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计3.4 等价类划分法等价类划分法3.4.1 3.4.1 等价类的划分原则等价类的划分原则3.4.2 3.4.2 等价类划分法的测试用例设计等价类划分法的测试用例设计3.4.3 3.4.3 常见等价类划分测试形式常见等价类划分测试形式3.4.4 3.4.4 使用等价类划分法测试的实例使用等价类划分法测试的实例ReturnSlide 13第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计等价类划分法等价类划分法n n等价类划分法是一种重要的、常用的黑盒测试方法,它将等价类划分法是一种重要的、常用的
17、黑盒测试方法,它将不能穷举的测试过程进行合理分类,从而保证设计出来的不能穷举的测试过程进行合理分类,从而保证设计出来的测试用例具有完整性和代表性。测试用例具有完整性和代表性。n n举例:设计这样的测试用例,来实现一个对所有实数进行举例:设计这样的测试用例,来实现一个对所有实数进行开平方运算(开平方运算(y=sqrt(x)y=sqrt(x))的程序的测试。)的程序的测试。思考方向:思考方向:由于开平方运算只对非负实数有效,这时需要将所有由于开平方运算只对非负实数有效,这时需要将所有的实数(输入域的实数(输入域x x)进行划分,可以分成:正实数、)进行划分,可以分成:正实数、0 0 和和 负实数。
18、假设我们选定负实数。假设我们选定+1.4444+1.4444代表正实数,代表正实数,-2.345-2.345代表代表负实数,则为该程序设计的测试用例的输入为负实数,则为该程序设计的测试用例的输入为+1.4444+1.4444、0 0 和和 -2.345-2.345。Slide 14第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计等价类划分法等价类划分法(续)(续)n n等价类划分法是把所有可能的输入数据,即程序的输入域等价类划分法是把所有可能的输入数据,即程序的输入域等价类划分法是把所有可能的输入数据,即程序的输入域等价类划分法是把所有可能的输入数据,即程序的输入域划分为若干部分(子
19、集),然后从每一个子集中选取少数划分为若干部分(子集),然后从每一个子集中选取少数划分为若干部分(子集),然后从每一个子集中选取少数划分为若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例。具有代表性的数据作为测试用例。具有代表性的数据作为测试用例。具有代表性的数据作为测试用例。n n所谓等价类是指某个输入域的子集合。所谓等价类是指某个输入域的子集合。所谓等价类是指某个输入域的子集合。所谓等价类是指某个输入域的子集合。在该子集合中,各在该子集合中,各个输入数据对于揭露程序中的错误都是等效的,它们具有个输入数据对于揭露程序中的错误都是等效的,它们具有等价特性,即每一类的代表
20、性数据在测试中的作用都等价等价特性,即每一类的代表性数据在测试中的作用都等价于这一类中的其它数据。这样,对于表征该类的数据输入于这一类中的其它数据。这样,对于表征该类的数据输入将能代表整个子集合的输入。因此,可以合理的假定:将能代表整个子集合的输入。因此,可以合理的假定:测试某等价类的代表值就是等效于对于这一类其它值测试某等价类的代表值就是等效于对于这一类其它值的测试。的测试。Slide 15第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计3.4.1 等价类的划分原则等价类的划分原则n n等价类是输入域的某个子集合,而所有等价类的并集就是等价类是输入域的某个子集合,而所有等价类的并集
21、就是整个输入域。因此,等价类对于测试有两个重要的意义:整个输入域。因此,等价类对于测试有两个重要的意义:完备性完备性完备性完备性整个输入域提供一种形式的完备性整个输入域提供一种形式的完备性无冗余性无冗余性无冗余性无冗余性若互不相交则可保证一种形式的无冗余性若互不相交则可保证一种形式的无冗余性n n如何划分?如何划分?如何划分?如何划分?先从程序的规格说明书中找出各个输入条先从程序的规格说明书中找出各个输入条件,再为每个输入条件划分两个或多个等价类,形成若干件,再为每个输入条件划分两个或多个等价类,形成若干的互不相交的子集。的互不相交的子集。n n采用等价类划分法设计测试用例通常分两步进行:采用
22、等价类划分法设计测试用例通常分两步进行:(1 1)确定等价类,列出等价类表。确定等价类,列出等价类表。确定等价类,列出等价类表。确定等价类,列出等价类表。(2 2)确定测试用例。)确定测试用例。)确定测试用例。)确定测试用例。Slide 16第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计等价类的划分原则等价类的划分原则(续)(续)n n划分等价类可分为两种情况:划分等价类可分为两种情况:(1 1)有效等价类)有效等价类 是指对软件规格说明而言,是有意义的、合理的输入是指对软件规格说明而言,是有意义的、合理的输入数据所组成的集合。利用有效等价类,能够检验程序是否数据所组成的集合。利用
23、有效等价类,能够检验程序是否实现了规格说明中预先规定的功能和性能。实现了规格说明中预先规定的功能和性能。(2 2)无效等价类)无效等价类 是指对软件规格说明而言,是无意义的、不合理的输是指对软件规格说明而言,是无意义的、不合理的输入数据所构成的集合。利用无效等价类,可以鉴别程序异入数据所构成的集合。利用无效等价类,可以鉴别程序异常处理的情况,检查被测对象的功能和性能的实现是否有常处理的情况,检查被测对象的功能和性能的实现是否有不符合规格说明要求的地方。不符合规格说明要求的地方。Slide 17第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计等价类的划分原则等价类的划分原则(续)(续)
24、n n进行等价类划分的依据:进行等价类划分的依据:(1)按照区间划分 在输入条件规定了取值范围或值的个数的情况下,可以确定一个有效等价类和两个无效等价类。例:例:程序输入条件为小于程序输入条件为小于100100大于大于1010的整数的整数x x,则有效等价类,则有效等价类为为1010 x x100100,两个无效等价类为,两个无效等价类为x10 x10和和x100 x100。例:例:程序输入程序输入x x取值于一个固定的枚举类型取值于一个固定的枚举类型1,3,7,151,3,7,15,且程序,且程序 中对这中对这4 4个数值分别进行了处理,则有效等价类为个数值分别进行了处理,则有效等价类为x=
25、1x=1、x=3x=3、x=7 x=7、x=15x=15,无效等价类为,无效等价类为x1,3,7,15x1,3,7,15的值的集合。的值的集合。(2)按照数值划分 在规定了一组输入数据(假设包括 n个 输入值),并且程序要对每一个输入值分别进行处理的情况下,可确定 n 个有效等价类(每个值确定一个有效等价类)和一个无效等价类(所有不允许的输入值的集合)。Slide 18第三章第三章 黑盒测试及其用例的设计黑盒测试及其用例的设计等价类的划分原则等价类的划分原则(续)(续)(3)按照数值集合划分 在输入条件规定了输入值的集合或规定了“必须如何”的条件下,可以确定一个有效等价类和一个无效等价类(该集
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 教学课件 教学 课件 黑盒 测试 及其 设计
限制150内