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