第7讲 黑盒测试二 ppt课件
合集下载
软件测试之黑盒测试-PPT精品文档
黑盒测试方法
• 黑盒测试方法主要包括:
–等价类划分法 –边界值分析法 –错误猜测法 –因果图法 –等等
等价类划分
• 是一种典型的黑盒测试方法。 • 能有效解决穷举法的不可行性,提高测 试的效率
等价类划分法
• 主要思想:
–根据被测对象的功能说明和输入域,按 合理的或不合理划分为若干等价类, –为每个等价类设计一个测试用例,这样 大大减少测试次数,提高测试效率。
1. 首先为等价表中的每一个等价类分配一个唯 一的编号。 2. 设计一个新的测试用例,使它能够尽量覆盖 尚未覆盖的有效等价类。重复这一步骤,从 而使所有有效等价类均被测试用例所覆盖。 3. 与第二步类似,设计一个新的测试用例,使 它只覆盖一个无效等价类。重复这一步骤, 从而使所有无效等价类均被测试用例所覆盖。
软件测试
黑盒测试方法
• 黑盒测试把测试对象看作一个黑盒,测试 人员不考虑程序的内部逻辑结构和内部特 性,只依据程序需求和功能规格说明,检 查程序上进行测试, 主要是为了发现以下错误:
–是否有不正确或遗漏了的功能? –在接口上,输入能否正确地接受? –能否输出正确的结果? –是否有数据结构错误或外部信息(例如数 据文件)访问错误? –性能上是否能够满足要求?是否有初始化 或终止性错误?
等价类
• 等价类是
–某个输入域的子集合。 –在该子集合中,各个输入数据对于揭露程序 中的错误都是等效的。 –测试某等价类的代表值就等价于对这一类其 它值的测试。
• 等价类可分为两种:有效等价类和无效等 价类。
–有效等价类是由那些对程序的规格说明有意义 的、合理的输入数据所构成的集合; –无效等价类则是那些对程序的规格说明不合理 的或无意义的输入数据所构成的集合。
第7章 黑盒测试技术
g f e
a bcd
28
软件测试
强健壮等价类测试
所有等价类笛卡儿积的每个元素中获得测试用例
g f e
a bcd
29
软件测试
等价类划分法示意图
有效等价类
有效等价类
弱一般等价类测试用例 含无效等价类
强一般等价类测试用例 含无效等价类
弱健壮等价类测试用例
30
强健壮等价类测试用例
软件测试
使用等价类设计测试用例的要点
软件测试
等价类划分的测试运用(续)
程序输出是由这3条边构成的三角形类型:
➢ 等边三角形、等腰三角形、一般三角形或非三角形。
如果a、b和c满足Con1、Con2和Con3,则输出下列4种情况 之一:
① 如果不满足条件Con 4、Con 5和Con 6中有一个,则程序输 出为“非三角形”。
② 如果三条边相等,则程序输出为“等边三角形”。 ③ 如果恰好有两条边相等,则程序输出为“等腰三角形”。 ④ 如果三条边都不相等,则程序输出为“一般三角形”。
输入条件
等价类表
有效等价类
无效等价类
…
…
…
…
…
…
22
软件测试
实例
需求是:对用户输入的分数进行评级,其中90到100 为A,80-89为B,70-79为C,60-69为D,60以下为E 。输入分数要求必须是正整数或0。根据分析得出以 下等价类划分?
输入条件
有效等价类
分数 0-59
60-69
70-79
10
软件测试
黑盒测试用例设计方法包括:
➢ 等价类划分法 ➢ 边界值分析法 ➢ 因果图法 ➢ 基于决策表的测试法 ➢ 功能图法 ➢ 判定表组成法 ➢ 正交实验设计法 ➢ ......
《黑盒测试》课件
3 未来发展趋势
随着软件系统的复杂性增加和技术的发展,黑盒测试将不断演进和完善,以满足新需求。
参考文献
• 相关学术论文和书籍
3 黑盒测试的局限性
一些内部缺陷可能无法通 过黑盒测试发现,测试覆 盖面有限,对于复杂系统 可能不够全面。
黑盒测试的方法
等价类划分法
将输入数据划分为等价类,以减少测试用例数量, 并覆盖不同输入情况。
边界值分析法
关注输入数据的边界情况,测试系统在边界处的 行为。
因果图法
通过绘制因果图,分析系统输入和输出之间的关 系,找出可能的故障点。
判定表方法
通过绘制判定表,列出不同输入条件下的所有情 况和相应的输出。
实例:使用等价类划分法进行测试
1
等价类划分法示例
假设有一个用户登录系统,输入用户名和密码进行登录。用户名可以是任意字符, 密码必须是6-12位数字。
2
实例分析
根据等价类划分法,我们可以选择一个有效用户名和一个有效密码,以及一些无 效的用户名和密码组合进行测试。
3
测试结果
通过等价类划分法,我们发现了系统在某些情况下无法正确处理无效用户名和密 码组合的问题。
黑盒测试的注意事项
1 测试数据的选择
选择代表不同情况的测试 数据,包括边界值和特殊 情况。
2 测试用例的设计
设计有效的测试用例,充 分覆盖系统的功能和可能 的错误情况。
3 测试用例的管理
建立有效的测试用例管理 系统,记录和跟踪测试用 例的执行和结果。
黑盒测试的应用
软件开发
黑盒测试在软件开发中广泛应用,帮助发现和修复 潜在问题,提高软件质量。
安全领域
黑盒测试可以通过模拟真实攻击的方式,评估系统 的安全性,发现潜在的漏洞和风险。
随着软件系统的复杂性增加和技术的发展,黑盒测试将不断演进和完善,以满足新需求。
参考文献
• 相关学术论文和书籍
3 黑盒测试的局限性
一些内部缺陷可能无法通 过黑盒测试发现,测试覆 盖面有限,对于复杂系统 可能不够全面。
黑盒测试的方法
等价类划分法
将输入数据划分为等价类,以减少测试用例数量, 并覆盖不同输入情况。
边界值分析法
关注输入数据的边界情况,测试系统在边界处的 行为。
因果图法
通过绘制因果图,分析系统输入和输出之间的关 系,找出可能的故障点。
判定表方法
通过绘制判定表,列出不同输入条件下的所有情 况和相应的输出。
实例:使用等价类划分法进行测试
1
等价类划分法示例
假设有一个用户登录系统,输入用户名和密码进行登录。用户名可以是任意字符, 密码必须是6-12位数字。
2
实例分析
根据等价类划分法,我们可以选择一个有效用户名和一个有效密码,以及一些无 效的用户名和密码组合进行测试。
3
测试结果
通过等价类划分法,我们发现了系统在某些情况下无法正确处理无效用户名和密 码组合的问题。
黑盒测试的注意事项
1 测试数据的选择
选择代表不同情况的测试 数据,包括边界值和特殊 情况。
2 测试用例的设计
设计有效的测试用例,充 分覆盖系统的功能和可能 的错误情况。
3 测试用例的管理
建立有效的测试用例管理 系统,记录和跟踪测试用 例的执行和结果。
黑盒测试的应用
软件开发
黑盒测试在软件开发中广泛应用,帮助发现和修复 潜在问题,提高软件质量。
安全领域
黑盒测试可以通过模拟真实攻击的方式,评估系统 的安全性,发现潜在的漏洞和风险。
黑盒测试课件
为每一个无效等价类至少设计一 个测试用例
测试数据 0a34 23456789
05 23456789 01234 23456789 2341 23456789
028 01234567 028 12345678 028 qw123456 028 623456 028 886234569
期望结果 显示无效输入 显示无效输入 显示无效输入 显示无效输入 显示无效输入 显示无效输入 显示无效输入 显示无效输入 显示无效输入
覆盖范围 (等价类编号)
8 9 10 11 12 13 14 15 16 17 18 19 20
错误推测法
所谓错误推测法就是指软件测试人员根据自身的经验和直 觉选择一些测试数据对可能会出现错误和容易发生错误的 地方进行测试。
例1:报表日期
设某公司要打印2001~2005年的报表,其中报表日期 为6位数字组成,其中,前4位为年份,后两位为月份。
6
日小于1
17
7月、8月、10月、12月
日大于31
18
月份为4月、6月、9月、 日在1与30之间
7
日小于1
19
11月
日大于30
20
等价类划分法示例
(2) 为有效等价类设计测试用例
序号
输入数据 年月日
预期输出 年月日
覆盖范围 (等价类编号)
1
2003 3 15 2003 3 16 1,2,3,6
覆盖等价类 (1),(2),(3),(4),(5),(6) (7) (8) (9) (10) (11) (12) (1),(2),(3),(4),(5),(6),(13) (1),(2),(3),(4),(5),(6),(14) (1),(2),(3),(4),(5),(6),(15) (1),(2),(3),(4),(5),(6),(16) (1),(2),(3),(4),(5),(6),(17) (1),(2),(3),(4),(5),(6),(14),(18) (1),(2),(3),(4),(5),(6),(15),(19) (1),(2),(3),(4),(5),(6),(13),(20)
黑盒测试.pptx
第一列字符必须是A或B,第二列字符 必须是一个数字,在此情况下进行文件 的修改,但如果第一列字符不正确,则 给出信息L;如果第二列字符不是数字, 则给出信息M。
2.3.3因果图法的例题
例题分析 原因:1——第一个字符是“A”
2——第一个字符是“B” 3——第二个字符是一个数字 结果: 21——修改文件; 22 ——给出信息L; 23——给出信息M。
招干考试分三个专业,准考证号第一位为专业代号, 如: 1-行政专业,
2-法律专业, 3-财经专业.
行政专业准考证号码为:110001~111215 法律专业准考证号码为:210001~212006 财经专业准考证号码为:310001~314015
2.1.3 等价类划分法例题
解:准考证号码的等价类划分 有效等价类: (1) 110001 ~ 111215 (2) 210001 ~ 212006 (3) 310001 ~ 314015
因果图法
22..11.1等什价么类是划等等什分价价么类类是?划分
等价类划分就是把输入数据的等价之划分 为若干等价类,因此,可以巴全部输入数据合 理地划分为若干等价类,在每一等价类中取一 个数据作为测试的输入条件,这样就能用少量 的代表性数据,来取得较好的测试结果。
等何都注等数试有说合了无价种是:价据才效 是 。 规 效类,等类,能设利 格 等等 合各 价:。 也 确计用 说 价价 理个指 的因 要 保测有 明类 的类输某为 能 软试效 中:,:与入个, 经 件用等 所是有有数输软受具例价规指意效据入件意有时类定对义等对域不外更,可的于的价揭的仅的高要检功程输类露子要考的同验能序入的程集能验可时和的数定序合接。靠考性规据义中。收这性虑是能格构恰在的合样。这否说 成。巧该错理 的两实明的相机误的 测种现集来反。
2.3.3因果图法的例题
例题分析 原因:1——第一个字符是“A”
2——第一个字符是“B” 3——第二个字符是一个数字 结果: 21——修改文件; 22 ——给出信息L; 23——给出信息M。
招干考试分三个专业,准考证号第一位为专业代号, 如: 1-行政专业,
2-法律专业, 3-财经专业.
行政专业准考证号码为:110001~111215 法律专业准考证号码为:210001~212006 财经专业准考证号码为:310001~314015
2.1.3 等价类划分法例题
解:准考证号码的等价类划分 有效等价类: (1) 110001 ~ 111215 (2) 210001 ~ 212006 (3) 310001 ~ 314015
因果图法
22..11.1等什价么类是划等等什分价价么类类是?划分
等价类划分就是把输入数据的等价之划分 为若干等价类,因此,可以巴全部输入数据合 理地划分为若干等价类,在每一等价类中取一 个数据作为测试的输入条件,这样就能用少量 的代表性数据,来取得较好的测试结果。
等何都注等数试有说合了无价种是:价据才效 是 。 规 效类,等类,能设利 格 等等 合各 价:。 也 确计用 说 价价 理个指 的因 要 保测有 明类 的类输某为 能 软试效 中:,:与入个, 经 件用等 所是有有数输软受具例价规指意效据入件意有时类定对义等对域不外更,可的于的价揭的仅的高要检功程输类露子要考的同验能序入的程集能验可时和的数定序合接。靠考性规据义中。收这性虑是能格构恰在的合样。这否说 成。巧该错理 的两实明的相机误的 测种现集来反。
黑盒测试及其测试实例PPT课件
.
9
划分等价类的规则 (5个)
(1)如果输入条件规定了取值范围,可定义一个有效等价 类和两个无效等价类。
例1.1: 输入值是学生成绩,范围是0~100。
无效等价类 成绩<0
0
100
有效 等价类 0≤成绩≤100
无效等价类 成绩>100
.
10
(2) 如果输入条件规定了输入值的集合,或者是规定 了“必须如何”的条件,这时可确立一个有效等价类 和一个无效等价类。
.
17
使用等价类划分法测试的实例
例1 三角形问题
分析:
在多数情况下,是从输入域划分等价类的,但并非不能从被测程序的输 出域反过来定义等价类,事实上,这对于三角形问题却是最简单的划分 方法。 在三角形问题中,有四种可能的输出:等边三角形、等腰三角形 、一般三角形和非三角形。利用这些信息能够确定下列输出(值域)等 价类。
例如,在教师上岗方案中规定对教授、副教授、讲师和助教分别 计算分数,做相应的处理。因此可以确定4个有效等价类为教授、 副教授、讲师和助教,一个无效等价类,它是所有不符合以上身 分的人员的输入值的集合。
.
13Байду номын сангаас
(5)在规定了输入数据必须遵守的规则的情况下(and关 系),可确立一个有效等价类(符合规则)和若干个无效等 价类(从不同角度违反规则,or关系)。
测试的方法与技术
静态测 试方法
软件测试的 策略和方法
动态测 试方法
人工测试方法 计算机辅助静 态分析方法 白盒测试方法 黑盒测试方法
.
1
黑盒测试方法是在程序接口上进行测试,主要是为了 发现以下错误:
是否有不正确或遗漏了的功能? 在接口上,输入能否正确地接受? 能否输出正确
黑盒测试学习课件
2.1.2 边界值分析法
边界点: 边界点分为上点、内点和离点
闭区间
半开半闭区间
开区间
离点
离点
离点
离点
离点
离点
上点
上点பைடு நூலகம்
上点
上点
上点
上点
内点
内点
内点
2.1.2 边界值分析法 (续)
边界值分析方法的原则: 如果输入(输出)条件规定了取值范围,则应该以该范围的边界值及边界附近的值作为测试数据; 如果输入(输出)条件规定了值的个数,则用最大个数,最小个数,比最小个数少一,比最大个数多一的数作为测试数据; 如果程序规格说明书中提到的输入或输出是一个有序的集合,应该注意选取有序集合的第一个和最后一个元素作为测试数据;
2.1 黑盒测试方法 (续)
黑盒测试的缺点有: 1)不可能覆盖所有的代码,覆盖率较低,大概只能达到总代码量的30%; 2)自动化测试的复用性较低。
2.1 黑盒测试方法 (续)
具体的黑盒测试用例设计方法包括等价类划分法、边界值分析法、错误推测法、因果图法、判定表驱动法、正交试验设计法、功能图法等。
2.1.1 等价类划分法 (续)
分析: (1)整数 (2)三个数 (3)非零数 (4)正数 (5)两边之和大于第三边 (6)等腰 (7)等边 如果 a 、 b 、 c 满足条件( 1 ) ~ ( 4 ),则输出下列四种情况之一: 如果不满足条件(5),则程序输出为 " 非三角形 " 。 如果三条边相等即满足条件(7),则程序输出为 " 等边三角形 " 。 如果只有两条边相等、即满足条件(6),则程序输出为 " 等腰三角形 " 。 如果三条边都不相等,则程序输出为 " 一般三角形 " 。
黑盒测试PPT课件
第二部分 黑盒测试
2021
1
测试分类
黑盒测试和白盒测试 静态测试(检查和审阅)和动态测试 (运行和使
用软件) 静态黑盒测试
对产品说明书进行高级审查 对产品说明书低级测试技术
2021
2
黑盒测试
黑盒测试着眼于程序外部结构,不考虑内 部逻辑结构,主要针对软件界面和软件功 能进行测试。
注重于测试软件的功能需求,主要试图发 现下列几类错误:
➢(4)(8)(10)(12) ➢(5)(9)(11)(13) ➢(6)(8)(10)(14) ➢(7)(8)(10)(14) ➢(1)(8)(10)(15) ➢(2)(9)(11)(16) ➢(3)(8)(10)(16)
说明:在设计无效部分的测试用例的时候,有效等价类部分,可以任意 选择。
2021
2021
4
黑盒测试的优、缺点
黑盒测试的优点有: 1)比较简单,不需要了解程序内部的代码及实现; 2)与软件的内部实现无关; 3)从用户角度出发,能很容易的知道用户会用到哪些功能,
会遇到哪些问题; 4)基于软件开发文档,所以也能知道软件实现了文档中的哪
些功能; 5)在做软件自动化测试时较为方便。 黑盒测试的缺点有: 1)不可能覆盖所有的代码,覆盖率较低,大概只能达到总代
2021
20
确立等价类的原则
如果规定了输入数据必须遵守的规则,则可以确立一个 有效等价类(即遵守规则的数据)和若干无效等价类 (从不同角度违反规则的数据),例如:
测试密码域,要求密码必须是数字或字母 有效等价类为“密码是数字和字母的组合”(还可以细分) 无效等价类为“密码包括中文”、“密码包括其它符号”等
2021
14
等价类划分
等价类划分法是一种重要的、常用的黑盒测试方法,它将不能穷举的测 试过程进行合理分类,从而保证设计出来的测试用例具有完整性和代表 性。
2021
1
测试分类
黑盒测试和白盒测试 静态测试(检查和审阅)和动态测试 (运行和使
用软件) 静态黑盒测试
对产品说明书进行高级审查 对产品说明书低级测试技术
2021
2
黑盒测试
黑盒测试着眼于程序外部结构,不考虑内 部逻辑结构,主要针对软件界面和软件功 能进行测试。
注重于测试软件的功能需求,主要试图发 现下列几类错误:
➢(4)(8)(10)(12) ➢(5)(9)(11)(13) ➢(6)(8)(10)(14) ➢(7)(8)(10)(14) ➢(1)(8)(10)(15) ➢(2)(9)(11)(16) ➢(3)(8)(10)(16)
说明:在设计无效部分的测试用例的时候,有效等价类部分,可以任意 选择。
2021
2021
4
黑盒测试的优、缺点
黑盒测试的优点有: 1)比较简单,不需要了解程序内部的代码及实现; 2)与软件的内部实现无关; 3)从用户角度出发,能很容易的知道用户会用到哪些功能,
会遇到哪些问题; 4)基于软件开发文档,所以也能知道软件实现了文档中的哪
些功能; 5)在做软件自动化测试时较为方便。 黑盒测试的缺点有: 1)不可能覆盖所有的代码,覆盖率较低,大概只能达到总代
2021
20
确立等价类的原则
如果规定了输入数据必须遵守的规则,则可以确立一个 有效等价类(即遵守规则的数据)和若干无效等价类 (从不同角度违反规则的数据),例如:
测试密码域,要求密码必须是数字或字母 有效等价类为“密码是数字和字母的组合”(还可以细分) 无效等价类为“密码包括中文”、“密码包括其它符号”等
2021
14
等价类划分
等价类划分法是一种重要的、常用的黑盒测试方法,它将不能穷举的测 试过程进行合理分类,从而保证设计出来的测试用例具有完整性和代表 性。
《黑盒测试培训》PPT课件
修正BUG的代价
需求 设计
编程 内部测试 外部测试 发布
一些常识和经验之谈
测试能提高软件的质量,但是提高质量不能依赖测试。 测试只能证明缺陷存在,不能证明缺陷不存在。“彻
底地测试”难以成为现实,要考虑时间、费用等限制, 不允许无休止地测试。我们应当祈祷:软件的缺陷在 产品被淘汰之前一直没有机会发作。 测试的主要困难是不知道如何进行有效地测试,也不 知道什么时候可以放心地结束测试。 每个开发人员应当测试自己的程序(份内之事),但 是不能作为该程序已经通过测试的依据(所以项目需 要独立测试人员)。 80-20原则:80%的缺陷聚集在20%的模块中,经常出 错的模块改错后还会经常出错 测试应当循序渐进,不要企图一次性干完,注意“欲 速则不达”。
很多人认为软件测试就是运行一下软件,看看结果对不对. 但实际上,如何在有限的投入下,提高软件测试的效率和产 出是一件很见功底的事.好的测试人员不仅要掌握各种测 试技术,还要具备丰富的编程经验和对BUG的敏感.测试的 复杂之处,除了测试技术问题之外,还有测试管理问题.
测试不是可有可无,随心所欲的.规范化的软件开发需要对 软件测试早做计划,分配必要的时间,人力和财力等资源,并 将其作为项目管理的一个部分加以控制和协调.
单元测试:是针对软件设计的最小单位—程序模块,进行 正确性检验的测பைடு நூலகம்工作。一般包括逻辑检查、结构检查、 接口检查、出错处理、代码注释、输入校验、边界值检查。
单元测试的依据是系统的详细设计;一般由项目组开发人 员自己完成。
集成测试:在单元测试的基础上,将所有模块按照设计要 求组装进行测试。一般包括逻辑关系检查、数据关系检查、 业务关系检查、模块间接口检查、外部接口检查。
(4)软件需求、设计报告、程序经常发生变更,每次变更都可能产生 新的Bug。
需求 设计
编程 内部测试 外部测试 发布
一些常识和经验之谈
测试能提高软件的质量,但是提高质量不能依赖测试。 测试只能证明缺陷存在,不能证明缺陷不存在。“彻
底地测试”难以成为现实,要考虑时间、费用等限制, 不允许无休止地测试。我们应当祈祷:软件的缺陷在 产品被淘汰之前一直没有机会发作。 测试的主要困难是不知道如何进行有效地测试,也不 知道什么时候可以放心地结束测试。 每个开发人员应当测试自己的程序(份内之事),但 是不能作为该程序已经通过测试的依据(所以项目需 要独立测试人员)。 80-20原则:80%的缺陷聚集在20%的模块中,经常出 错的模块改错后还会经常出错 测试应当循序渐进,不要企图一次性干完,注意“欲 速则不达”。
很多人认为软件测试就是运行一下软件,看看结果对不对. 但实际上,如何在有限的投入下,提高软件测试的效率和产 出是一件很见功底的事.好的测试人员不仅要掌握各种测 试技术,还要具备丰富的编程经验和对BUG的敏感.测试的 复杂之处,除了测试技术问题之外,还有测试管理问题.
测试不是可有可无,随心所欲的.规范化的软件开发需要对 软件测试早做计划,分配必要的时间,人力和财力等资源,并 将其作为项目管理的一个部分加以控制和协调.
单元测试:是针对软件设计的最小单位—程序模块,进行 正确性检验的测பைடு நூலகம்工作。一般包括逻辑检查、结构检查、 接口检查、出错处理、代码注释、输入校验、边界值检查。
单元测试的依据是系统的详细设计;一般由项目组开发人 员自己完成。
集成测试:在单元测试的基础上,将所有模块按照设计要 求组装进行测试。一般包括逻辑关系检查、数据关系检查、 业务关系检查、模块间接口检查、外部接口检查。
(4)软件需求、设计报告、程序经常发生变更,每次变更都可能产生 新的Bug。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
1. 决策表的原理
– 决策表(Decision Table),又叫决策表
– 决策表是分析和表达多逻辑条件下执行不同 操作的工具。
– 在程序设计发展的初期,决策表被当作编写 程序的辅助工具。
广州大学华软软件学院
6
1.1.1决策表
2. 决策表的组成
• 条件桩(Condition Stub)
– 列出问题的所有条件
广州大学华软软件学院
18
1.1.1决策表
例:维修机器问题(续)
❖ (4)填入动作项;
1 2 3 4 5 6 78
功率大于50马力吗? Y Y Y Y N N N N
条 维修记录不全吗? Y Y N N Y Y N N 件 运行超过10年吗? Y N Y N Y N Y N
动 进行优先处理 作 作其他处理
广州大学华软软件学院
23
1.1.2 基于决策表的测试
• (3)动作桩
– A1:非三角形; – A2:不等边三角形; – A3:等腰三角形; – A4:等边三角形; – A5:不可能;
广州大学华软软件学院
24
1.1.2 基于决策表的测试
• (4)决策表
a, b, c构成三角形
12 3 4 5 6 7 89 NY Y Y Y Y Y YY
其条件项之间存在着极为相似的关系,就 可以将规则合并。
广州大学华软软件学院
11
1.1.1决策表
(1)两条规则合并成一条
• 条件项“— ”表示与取 值无关。
广州大学华软软件学院
12
1.1.1决策表
(2)两条规则的进一步合并
• 条件项“— ”在逻辑上 包含其它的 条件。
广州大学华软软件学院
13
1.1.1决策表
广州大学华软软件学院
3
1.1 基于决策表的测试
内容: ❖ 决策表 ❖ 基于决策表的测试 ❖ 案例:三角形问题,NextDate问题 ❖ 练习:隔一日问题
广州大学华软软件学院
4
1.1.1决策表
• 决策表的原理 • 决策表的组成 • 决策表建立的步骤
广州大学华软软件学院
5
1.1.1决策表
• 决策表
条 a = b? 件
a = c?
b = c?
非三角形
不等边三角形
动 作
等腰三角形
等边三角形
不可能
—Y Y Y Y N N N N —Y Y N N Y Y N N —Y N Y N Y N Y N ✓
17
1.1.1决策表
例:维修机器问题(续)
❖ (3)填入条件项;
123 4 5 6 7 8
功率大于50马力吗? Y Y Y Y N N N N
条 维修记录不全吗? 件
运行超过10年吗?
YYN N Y Y YNY N Y N
NN YN
动 进行优先处理 作 作其他处理
❖ 利用集合的笛卡尔积计算条件项的取值
• 动作桩(Action Stub)
– 列出可能采取的操作
• 条件项(Condition Entity)
– 列出条件桩的取值
• 动作项(Action Entity)
– 列出条件项各种取值下应该采取的动作
广州大学华软软件学院
7
1.1.1决策表
决策表的组成
广州大学华软软件学院
8
1.1.1决策表
规则
• 任何一个条件组合的特定取值及其相应要执行的操 作称为规则;
例:维修机器问题
• 问题描述:
– “……对于功率大于50马力的机器, 并且维修记录不全或已运行10年以上 的机器,应给予优先的维修处理 ……”
• 请建立决策表。
广州大学华软软件学院
15
1.1.1决策表
例:维修机器问题(续)
• (1)列出所有的条件桩和动作桩
–条件桩
• C1:功率大于50马力吗? • C2:维修记录不全吗? • C3:运行超过10年吗?
• 请用基于决策表的方法设计测试用例。
广州大学华软软件学院
22
1.1.2 基于决策表的测试
一、设计决策表
• (1)条件桩
– C1:a,b,c构成三角形? – C2:a = b? – C3:a = c? – C4:b = c?
• (2)规则数
– 共有四个条件,每个条件的取值为“是”或“否”
,因此有24= 16条规则。
3. 决策表建立步骤
• 根据软件规格说明
– ①列出所有的条件桩和动作桩; – ②确定规则的个数;
• 假如有n个条件,每个条件有两个取值(0,1),则 有2n 种规则;
– ③填入条件项; – ④填入动作项,得到初始决策表; – ⑤简化,合并相似规则(相同动作)。
广州大学华软软件学院
14
1.1.1决策表
广州大学华软软件学院
软件测试 技术案例教程
第四章 黑盒测试(二)
CONFIDENTIAL
本节主要内容
1. 决策表 2. 因果图 3. 错误推测法 4. 项目案例
广州大学华软软件学院
2
上节内容回顾
1. 黑盒测试概念 2. 等价类测试 3. 边界值分析法 4.项目案例
–动作桩
• A1:进行优先处理 • A2:作其他处理
广州大学华软软件学院
16
1.1.1决策表
例:维修机器问题(续)
• (2)确定规则个数
功率大于50马力吗 维修记录不全吗 运行超过10年吗
– 输入条件个数:3;
– 每个条件的取值:“是”或“否”;
– 规则个数:2*2*2 =8;
广州大学华软软件学院
✓✓
✓
✓
✓
广州大学华软软件学院
20
1.1.2 基于决策表的测试
• 根据输入输出绘制决策表; • 设计测试用例覆盖决策表中每条规则;
广州大学华软软件学院
21
1.1.2 基于决策表的测试
4.3.3 案例:三角形问题
• 问题描述
输入三个正整数a、b、c,分别作为三角形的三条 边,通过程序判断三条边是否能构成三角形?如果 能构成三角形,判断三角形的类型(等边三角形、 等腰三角形、一般三角形)。
• 在决策表中贯穿条件项和动作项的一列就是一条规 则;
• 决策表中列出多少组条件取值,也就有多少条规则 ,即条件项和动作项有多少列。
广州大学华软软件学院
9
1.1.1决策表 规则示例:三角形问题
广州大学华软软件学院
10
1.1.1决策表
规则(续)
• 规则合并
– 规则合并就是决策表的简化。 – 有两条或多条规则具有相同的动作,并且
✓✓✓ ✓ ✓ ✓ ✓✓
❖ 1,2合并,5,7合并,6,8合并
广州大学华软软件学院
19
1.1.1决策表
例:维修机器问题(续)
• (5)化简;
(1) (2) (3) (4) (5)
功率大于50马力吗? Y Y Y N N
条 维修记录不全吗? 件
运行超过10年吗?
Y N N —— —Y N Y N
动 进行优先处理 作 作其他处理