第6课 测试用例设计
1.黑盒测试方法
2.白盒测试方法
术语一:
• 动态测试(dynamic testing):通过运行软件的组
件或 系统来测试软件
• 静态测试(static testing):对组件的规格说明书
进行 评审,对静态代码进行走查
• 正式评审(formal review):对评审过程及需求文
档的 一种特定评审
• 度量(metric):测量所使用的方法或标准
• 评审员(reviewer):参与评审的人
• 记录员(scribe):记录评审会议上的会议纪要
术语二:
• 技术评审(Technical Review):同行间对技术进行的评审,
目的是技术实现达成共识。
• 走查(Walkthrough):由文档作者逐步陈述文档内容,以
收集信 息并对内容达成一致
• 复杂性(complexity):系统或组件的设计或内部结构比较
复杂, 导致难以理解,维护或验证的程度
• 圈复杂度(Cycloramic complexity):程序中独立路径的数
量。可 以衡量一个组件模块的判定结构的复杂程度。
• 控制流(Control Flow):执行组件或系统的一系列顺序的路
径
• 数据流(Data Flow):表示数据对象的顺利或状态发生变
化的过程
圈复杂度:
• 程序中独立路径的数量,可以衡量 一个组件模块
的判定结构的复杂程 度。三种计算方式:
a.圈复杂=区域数
b.圈复杂度=边数-节点数+2
c.圈复杂度=判定节点+1
用例设计方法
一、黑盒设计测试用例方法
1、等价类,边界值,判定表,因果图,正交表,场景 法,状态迁移法
2、错误推测法,异常分析法,随机测试
二、白盒测试设计用例方法
1、语句覆盖
2、判断覆盖
3、条件覆盖
4、判断条件覆盖
5、路径覆盖(独立路径覆盖,z路径)
等价类:指某个输入域的集合,在集合中各个输 入的条件都是等效的。
通常等价类划分为2种情况:
有效等价类:对程序规格说明有意义的、合理 的输入数据
无效等价类:对程序规格说明无意义的、不合 理的输入数据
**等价类划分的设计用例思路: **
- 找输入条件
- 为每个输入条件找有效、无效等价类
- 为每个等价类编号
- 用最少的用例覆盖最多的有效等价类
- 每一个无效等价类都是一个用例
- 并非所有有效等价类都有无效
- 等价类的覆盖可以重复覆
等价类设计用例覆盖的原则:
• 每个用例尽可能多的覆盖多个有效的等价类
• 每个用例只能覆盖一个无效等价类
常见的能够划分等价类的地方: - 数值范围
- 重复次数
- 字符串长度
- 字符串组中字符的个数
- 文件命名
- 文件大小
- 屏幕的颜色种类
- 超时时间
等价类的优缺点 优点:是考虑了单个输入域的各类情况, 避免
了盲目或随机选取输入数据的不完整 性和覆盖
的不稳定性。 缺点:方法虽然简单易用,但是没有对组 合情
况进行充分的考虑。需要结合其他测 试用例设
计的方法进行补充。比如边界值
一、边界点定义:
1)边界上的点
(2)离点:离上点最近的点(即上点左右两边最邻近的点)
(3)内点:在域范围内的点:
边界条件分析: - 输入条件明确了一个值的取值范围,或规定了值的个数
- 输入条件明确了一个有序集合边界值分析原则
- 如果输入(输出)条件规定了取值范围,则应该 以该范 围的边界内及边界附近的值作为测试用例
- 如果输入(输出)条件规定了值的个数,则用最 大个数,最小个数,比最小个数少一,比最大个 数多一的数作为 测试数据
- 如果程序规格说明中提到的输入或输出是一个有 序集合,应该注意选取有序集合的第一个和最后 一个元素作为测 试数据
边界值是发现错误能力最强的设计用例方法
判定表定义: 分析和表达多逻辑条件下的执行不同操作的情况
2、作用:对组合情况设计用例
利用判定表将复杂的问题按照各种可能的 情况全部列举出来,能针对不同逻辑条件 的组合值,
分别执行不同的操作。
3、组成部分:
1)条件桩(condition stub):列出问题的 所有条件(通常条件次序无关紧要)。
2)条件项(condition entry):列出针对 它条件的取值(所有情况下的真假值)
3)动作桩(action stub):列出问题规定 可采取的动作(顺序无约束)。
4)动作项(action entry):列出条件各种情况的应采取的 动作
4、创建步骤:
1)确定规则的个数:若有N个条件,每一个条件下有2个值,则有2^n种规则。
2)列出所有条件桩与动作桩。
3)输入条件项。
4)输入动作项得到初始判定表。
5)简化(合并相似规则)。
6)编写测试用例
案例1:
对功率大于50马力的机器、维修记录不全或已运行10年以上的机器,应给予优先的维修处理……”。
理解:1、 功率大于50马力的机器 和维修记录不全(优先)
2、已运行10年以上的机器(优先)
备注:条件3个 2的3次方=8次, 8次可以覆盖所有的组合情况
a.初始化判定表
b.简化后的判定表
因果图:
(1)定义:因果图提供了一个把规格转化为判定表的系统化方法,从该图中可以产生测试数据。其 中,
原因是表示输入条件,结果是对输入执 行的一系列计算后得到的输出
(2)作用:因果图方法最终生成的就是判定表。它适合于检查软件输入条件的各种组合情况
(3)
a.因果图中的约束
在实际问题中输入状态相互之间、输出状 态相互之间可能存在某些依赖关系,称为“约 束”。对于输入条件的约束有E、I、O、R四种 约束,
对于输出条件的约束只有M约束。
ØE约束(异):a和b中最多有一个可能为1,即a和b不能 同时 为1。
ØI 约束(或):a、b、c中至少有一个必须为1,即 a、b、 c不能同时为0。
ØO约束(唯一):a和b必须有一个且仅有一个为1。
ØR约束(要求):a是1时,b必须是1,即a为1时,b不能 为0。
ØM约束(强制):若结果a为1,则结果b强制为0。
b.因果图中的4种基本关系
在因果图的基本符号中,图中的左结点ci 表示输入状态(或称原因),右结点ei表示输出 状态(或称结果)。
ci与ei取值0或1,0表示某 状态不出现,1则表示某状态出现。
Ø恒等:若 c1 是1,则 e1 也为1,否则 e1 为0。案例1:有钱=富豪
Ø非:若 c1 是1,则 e1 为0,否则e1为1。案例2:有钱=穷人
Ø或:若 c1 或 c2 或 c3 是1,则 e1 为1,否则 e1 为0。案例3:
有车、
有房、 满足一个有钱人
有存款
Ø与:若 c1 和 c2 都是1,则 e1 为1,否则 e1 为0。案例4:
有车、
有房、 满足三个是:有钱人
有存款
(4)
因果图转换判定表的方法:
- 将因果图中的所有条件(因)填入判定表 的条件桩中;
- 将因果图中的所有动作(果)填入判定表 的动作桩中;
- 根据因果图确定各个条件组合对应的动作, 并且确定判定表中各个规则的条件项和动 作项,
在需要时优化判定表。
(5)
:
1.把大的系统规格划分解成可以测试的规格片段
2.分析分解后待测的系统规格,找出哪些是原因,哪些是结果
3.画出因果图
4.把因果图转换成判定表
5.简化判定表
6.用判定表中的每一列生成测试用例
(6)
因果图的优点/缺点
优点: - 等价类法尽管各个输入条件可能出错的情况都考虑 到了,但是多个输入条件组合起来出错的情况却被 忽略了
- 因果图法能够帮助我们按照一定步骤,高效的选择 测试用例,设计多个输入条件组合用例
- 因果图分析还能为我们指出,程序规格说明描述中 存在什么问题
缺点: - 输入条件与输出结果的因果关系,有时难以从软件 需求规格说明书得到
- 即使得到了这些因果关系,也会因为因果关系复杂 导致因果图非常庞大,测试用例数目及其庞大
场景法
(1)定义:场景法主要是针对测试场景类型的,顾也称场景流程分析法
(2)流程分析:是将软件系统的某个流程看成路径,用路径分析的方法来设计测试用例。根据流程的顺序依次进行组合,使得流程的各个分支都能走到
(3)熟悉xmind思维导图(也称脑图),梳理测试点,和测试流程
(4)流程分析步骤: - 画出业务流程图 注:描述正常流程和异常流程
- 确定条件分支(功能路径) 注:设计路径的优先级
- 确认测试路径 注:考虑路径覆盖率
- 选择数据构造用例 注:选数据要结合等价类边界值分析
正交试验
(1)定义:
正交试验设计法,是从大量的试验点中挑选出适量的、有代表性的点,应用依据迦罗瓦理论导出的“正交表”,合理的安排试验的一种科学的试验设计方法。
设计测试用例方法之状态迁移法(重要
(1)通过描绘系统的状态及引起系统状态转换的事件,来表示系统的行为
(2)状态迁移图设计测试用例步骤:
1.画出状态迁移图
2.通过状态迁移图出状态转换树
3.从状态转换树推导出测试路径
4.根据测试路径编写合法(正常)测试用例或非法(异常)测试用例
注意:保证从状态转换树的根节点到每个叶节点的每一条路径都至少设计出一个测试用例
设计测试用例方法之经验测试法(重要)
一.错误推测法、
基于经验的测试技术之错误推测法
错误推测法也叫错误猜测法,就是根据经验猜想,已有的缺陷,测试经验和失败数据等可能有什么问题并依此设计测试用例.
二、异常分析法
基于经验的测试技术之异常分析法
系统异常分析法就是针对系统有可能存在的异常操作、软硬件缺陷引起的故障进行分析,依此设计测试用例。
主要针对系统的容错能力、故障恢复能力进行测试
三、随机测试
基于经验的测试技术之随机测试
随机测试指的是测试中的所有的输入数据都是随机生成的,其目标是模拟用户的操作。真实环境中,尤其是软件刚刚发布时,会有成千上万的人在上面乱敲乱试;
因此在发布软件前,用模拟用户的随机测试就可能发现其它方式漏掉的软件缺陷
设计测试用例方法之正交实验法_
(1)定义:正交试验设计法,是从大量的试验点中挑选出适量的、有代表性的点,应用依据迦罗瓦理论导出的“正交表”,合理的安排试验的一种科学的试验设计方法。
(2)正交常用的术语
指标:通常把判断试验结果优劣的标准叫做试验的指标
因子:所有影响试验指标的条件
水平值:影响试验因子的取值
(3)正交表特点
正交表特点:
1》整齐可比性
在同一张正交表中,每个因素的每个水平出现的次数是完全相同的。由于在试验中每个因素的每个水平与其它因素的每个水平参与试验的机率是完全相同的,这就保证在各个水平中最大程度的排除了其它因素水平的干扰。
2》均衡分散性
在同一张正交表中,任意两列(两个因素)的水平搭配(横向形成的数字对)是完全相同的。这样就保证了试验条件均衡地分散在因素水平的完全组合之中,,因而具有很强的代表性,容易得到好的试验条件
(4)用正交表设计测试用例的步骤:
(1)有哪些因素(变量或条件)
(2) 每个因素有哪几个水平(变量或条件的取值)
(3) 为了满足整齐可比性,选择一个合适的正交表
(4) 把变量的值映射到表中(建议第1行是全真或全假)
(5) 把每一行的各因素水平的组合做为一个测试用例
(6) 加上你认为可疑且没有在表中出现的组合
白盒测试技术
(1)白盒测试(结构测试或者逻辑驱动测试)
定义:白盒测试也叫透明盒测试,检查程序内部结构及路径一是否符合规格说明,二是否符合其代码规范。
(2)白盒测试常见方法:
a.语句覆盖;
b.判断覆盖(也称“分支覆盖”);
c. 条件覆盖;
d.判断、条件覆盖;
e.条件组合覆盖;
f.路径覆盖 (分为:z路径和独立路径)
3)详解白盒测试方法
1、语句覆盖:
指设计若干个测试用例,使得程序运行时,每个可执行语句至少被执行一次
2、判断覆盖(分支覆盖):
指设计若干个测试用例,使得程序运行时,每个判断条
件的真假分支至少被执行一次
3、条件覆盖:
指设计若干个测试用例,使得程序运行时,每个判断条件中的每个判断式的真、假值至被执行一次
4、判断、条件覆盖:
指设计若干个测试用例,使得程序运行时,每个判断条件中真、假值分支至少被执行一次,且每个判断条件的内部判断式的真、假值至少被执行一次。判断、条件覆盖:
5、条件组合覆盖:
指设计若干个测试用例,使得程序运行时,每个判断条件的内部判断式的各种真假组合都至少被执行一次;是逻辑覆盖测试中“覆盖能力”最强的。
6、一.路径覆盖:
旨在保证程序中每一个特定的路径方案都能正常运行。
常见的路径覆盖方法:2种
A:独立路径覆盖
定义:即覆盖所有的独立路径的测试,所谓独立路径应至少包含一条在其它路径中从未有过的边
B:Z路径覆盖
二、Z路径覆盖:是一种将实际项目中复杂的程序减少其循环次数的路径覆盖方法,
即:不考虑循环体实际需要执行多少次,只考虑通过循环体0次和1次这两种情况
Z路径覆盖:0次循环:直接跳过循环体,从循环体入口直接到出口
1次循环:通过一次循环体即可
备注: &&(短路与), ||(短路或),
白盒测试方法的优点:
1.深入程序内部,测试粒度较细。
2.是测试用例设计方法的组成部分,也是黑盒测试方法的有力补充。
3.为自动化测试与性能测试奠定基础。
白盒测试方法的缺点:
1.过分关注代码本身,容易偏离SRS实际需求
2.对相应的编程语言要求较高,人力成本较大