软件工程--白盒测试技术 ppt课件
白盒测试PPT课件
软件技术专业国家教学资源库——《软件测试》课程
3
本项目各任务的教学过程
➢ 项目概述 ➢任务一 ➢任务二 ➢任务三
软件技术专业国家教学资源库——《软件测试》课程
4
项目概述
引例
如何清理面包机?
不管内部,拿水从入口往下灌着冲洗 将面包机拆开一点点的查看有无锈迹污迹,逐个清理
白盒测试
测试者针对可见代码进行的一种测试
1
if((a+b<=c) || (a+c<=b) || (b+c<=a)){
2
printf("不能构成三角形");
3
}else{
4
if((a==b) ||(b==c)||(a==c)){
5
if((a==b)&&(b==c)){
6
printf("等边三角形");
7
}else{
8
printf("等腰三角形");
➢ 任务简介 ➢ 任务分析 ➢ 相关知识点 ➢ 任务实施 ➢ 任务小结 ➢ 拓展训练
软件技术专业国家教学资源库——《软件测试》课程
7
项目概述
待测程序说明
图形识别系统
根据输入的信息确定最终图形的种类
主要测试的程序片段---三角形问题
接受输入三个整数a、b、c,分别作为三角形的三条边,通 过程序判断这三条边是否能构成三角形?如果能构成三角形, 则判断三角形的类型(等边三角形、等腰三角形、一般三角 形)。要求输入三个整数a、b、c,必须满足以下条件: 1≤a≤200;1≤b≤200;1≤c≤200。
9
}
10
}else{
白盒测试ppt课件
控制流图: 为了更加突出控 制流的结构,需 要对程序流程图 做些简化,这种 简化了的流程图 称为控制流图。
11
控制流图
控制流图中的符号: ①节点:以标有编号的圆圈 表示,代表程序流程图中矩 形框所表示的处理、菱形表 示的分支及多选择结构点。 ②控制流线:以带箭头的直 线或弧表示,与程序流程图 中的数据流线是一致的,表 明了控制的顺序。控制流线 通常标有名字,如图中所标 的a、b、c等。
测试完成?
是
6
关闭测试任务
1,2 3,4 5 6
18
问题?
n 如果判断中的条件表达式是由一个或多个逻辑 运算符 (OR, AND, NAND, NOR) 连接的复合条件 表达式,则需要改为一系列只有单条件的嵌套的 判断。 例如:
1 if a or b 2x 3 else 4y 对应的逻辑为:
数据流分析
15
如何画控制流图
1. n 在选择或多分支结构中,分支的汇聚处应有 一个汇聚结点。
13 14
21
17
23
2. 选择的行号的代码都是出现了选择分支,循 环操作,判断等, 顺序执行的语句可以合并 。 这也是画控制流图的一般规则。
17
1
编写、修改测试用例
2
进入测试任务
3
执行测试用例
4
输入测试结果
否
5
23
控制流测试基本概念
一、基本概念 有向图 路径 完整路径 简单路径 基本路径 子路径 回路 无回路路径 连接 覆盖
24
有向图:有向图G=(V,E),V是顶点的集合,E是 有向边的集合。e=(T(e),H(e))∈E是一对有 序的邻接节点,T(e)是尾,H(e)是头。如果H(e) =T(e’),则e和e’是临界边。H(e)是T(e)的后继 节点,T(e)是H(e)的前驱节点,indegree(n)和 outdegree(n)分别是节点n的入度和出度。
《白盒测试法》课件
结论
通过本课件的学习,您将了解到白盒测试法的特点和应用价值,以及如何利用它来提高软件质量和可靠性。
白盒测试法的应用场景
白盒测试法适用于需求明确、具有复杂逻辑结构或高风险的软件项目,可以有效发现隐藏的 代码错误和漏洞。
白盒测试法的测试对象
白盒测试法适用的测试对象
白盒测试法适用于各种类型的软件系统,包括
白盒测试法不适用的测试对象
白盒测试法通常不适用于硬件电路和不需要了解内 部实现的功能简单软件模块。
白盒测试法的测试方法
1
动态测试方法
2
通过运行程序并监视其行为,动态测试 方法可以评估测试用例对程序的覆盖情
况并验证其正确性。
静态分析方法
通过分析代码的控制流、数据流和符号 执行等方法,静态分析可以提供关于程 序结构和行为的静态信息。
《白盒测试法》PPT课件
欢迎参加《白盒测试法》课件!这是一个关于白盒测试法的详细介绍,并包 括其定义、应用场景、测试对象、测试方法、优缺点以及应用示例的内容。
什么是白盒测试法
白盒测试法的定义
白盒测试法是一种软件测试方法,通过了解被测试系统的内部实现和代码结构,设计测试用 例并验证系统的正确性和可靠性。
白盒测试法的优缺点
优点
• 可以发现代码错误和漏洞 • 能提高代码质量和可靠性
缺点
• 需要了解被测试系统的内部实现 • 测试难度大,测试成本高
白盒测试法的应用示例
代码示例分析
通过对一个实际代码段的分析,演示如何使用白盒测试法来设计测试用例和验证代码的正确性。
白盒测试用例设计实例
提供一个详细的实例,展示如何根据白盒测试法的原则和技巧来设计测试用例,并对被测试系统进行全面的测 试。
软件测试工程师培训-测试技术基础PPT课件
28
2.2 软件开发与软件测试- 开发各阶段的测试工作
▪ 详细设计和概要设计阶段: – 确保集成测试计划和单元测试计划完成。 – 测试计划完成后,对参考的设计文档进行修改。
输入
输出
黑盒测试又称功能测试、数据驱动测试或基于 规格说明的测试,也可被成为用户测试,主要 应用于快速应用开发(RAD)环境
41
2.4 测试方法-白盒测试
▪ 白盒测试的前提是可以把程序看成装在一个 透明的白盒子里,也就是完全了解程序结构 盒处理过程,这种方法按照程序内部逻辑测 试程序,检验程序中每条通路是否按预定要 求正确工作。
–测试无法说明错误不存在,只能说明 软件错误已出现。
13
2.1 软件测试的定义
14
2.1 软件测试的定义
▪ 软件测试的原则 – 尽早地和不断地进行软件测试 – 避免测试自己的程序 – 执行测试计划,排除随意性 – 增量测试,由小到大 – 周密的测试用例(输入条件(合理、不合理)、 预期输出结果)
进行跟踪。 ▪ 代码审查关注下列类型问题: (1)数据引用错误(2)数据说明(3)计算(4)比较 (5)控制流(6)接口(7)输入/输出(8)其它检查
46
2.4 测试方法
人工走查(Walkthroughs) ▪ 人工走查与代码审查一样,首先通过资料,
研究程序。但不同的是:在人工走查会上是 通过测试数据与人工运行程序来达到测试目 的。 ▪ 对照实验发现,人工走查和审查会平均能查 出被测程序38%的错误。据资料,IBM代码 审查会的查错效率高达80%。
8
第3章白盒测试技术
函数调用关系图
• 通过应用程序各函数之间的调用关系展示 了系统的结构。列出所有函数,用连线表 示调用关系。 • 通过函数调用关系图:
– 可以检查函数的调用关系是否正确 – 是否存在孤立的函数而没有被调用 – 明确函数被调用的频繁度,对调用频繁的函数 可以重点检查
模块控制流图
• 模块控制流图是与程序流程图类似的有许 多节点和连接节点的边组成的一种图形, 其中一个节点代表一条语句或数条语句, 边表示节点间的控制流向,它显示了一个 函数的内部逻辑结构 • 模块控制流图可以直观的反映出一个函数 的内部逻辑结构,通过检查这些模块的控 制流图,能够很快发现软件的错误与缺陷。
逻辑覆盖法
• 逻辑覆盖是通过对程序逻辑结构的遍历实现程序 的覆盖。它是一系列测试过程的总称,这组测试 过程逐渐进行越来越完整的通路测试。 • 从覆盖源程序语句的详尽程度分析,逻辑覆盖标 准包括:
– – – – – – 语句覆盖 判定覆盖 条件覆盖 条件判定组合覆盖 多条件覆盖 修正条件判定覆盖
示例程序
3.3 动态测试技术
• 白盒测试的动态测试应该根据程序的控制结构设计测试用例,原则是:
– – – – 保证模块中每一独立的路径至少执行一次; 保证所有判断的每一分枝至少执行一次; 保证每一循环都在边界条件和一般条件下至少各执行一次; 验证所有内部数据结构的有效性。
• 对一个具有多重选择和循环嵌套的程序,不同的路径数目可能是天文数 字.而且即使精确地实现了白盒测试,也不能断言测试过的程序完全正 确. • 比如包括了一个执行达20次的循环的程序,它所包含的不同执行路径 数高达520条,假使有这么一个测试程序,对每一条路径进行测试需要 1ms,假设一天工作 24小时,一年工作365天,若要对它进行穷举测试,也 需要3024年的时间. • 为了节省时间和资源,就必须精心设计测试用例,从数量巨大的可用 测试用例中挑选少量的、优秀的测试数据,使用这些测试数据能够达 到最佳的测试效果 • 其中,逻辑覆盖法和基本路径测试法是常用的两种白盒测试用例测试 方法。
软件测试培训教程(精品PPT)
软件测试概论(gàilùn)〔行情〕
国外:
A、软件测试在软件公司中占有重要(zhòngyào)的地位 B、软件测试理论研究蓬勃开展,引领软件测试理论研究
的国际潮流
C、软件测试市场繁荣
国内: 1、我国著名的软件公司都已经或者正在建立独立的专职软
件测试队伍 2、国家开始对软件测试职业高度重视和认可〔软考中级资
需求分析,概要设计,详细设计以及程序编码等各阶段 所得到的文档,包括需求规格说明,概要设计规格说明, 详细设计规格说明以及源程序。
第十九页,共一百九十四页。
软件测试的对象(duìxiàng)
为了把握各个环节的正确性,人们需要进行各种验证和确 认工作 :
❖ 验证(verification): 是保证软件正确实现特定功能的一系 统活动和过程,目的是保证软件生命周期中的每一个阶段的 成果满足上一个阶段所设定的目标。
初 学 者
QTP功能测试 工具学习
LoadRunner性 能测试工具学习
软件测试理论 基础学习
缺陷管理 知识学习
数据库 知识学习
配置管理 知识学习
项目实战
岗前培训 面试技巧
图1-3 软件测试学习路线图
Web测试环境 搭建学习
Linux操作系统 知识学习
工 作
第十一页,共一百九十四页。
软件测试由来
❖调试
测试(cèshì)工程师的职业开展
❖ 软件测试工程师一般有几个(jǐ ɡè)方向可走,如图1-2所示。
初级测试工程师 中级测试工程师
高级测试工程师
测试管理者
图1-2 职业发展规划图
开发工程师
❖ 一个理想的测试工程师应该有开发经验,至少要有开发 的概念。仅仅发现Bug是测试的初步,而分析出根本原 因,却要有很深的功底。
《白盒测试法》课件
优点
代码覆盖率高
白盒测试法能够深入到代码的 逻辑结构中,对代码进行详细 的覆盖,从而确保测试的全面
性。
测试质量高
由于白盒测试法能够深入了解 代码逻辑,因此能够发现更深 层次的代码错误和缺陷,提高 测试质量。
可针对需求定制
白盒测试法可以根据具体的软 件需求和设计进行定制化的测 试,从而更好地满足测试需求 。
04
白盒测试法的工具
JUnit
JUnit是一个Java语言的单元测试框架,用于编写和执行测试用例,验证代码的正确 性和可靠性。
JUnit提供了一系列的注解和断言方法,方便开发者编写测试代码,并且支持测试套 件和测试运行器的概念,可以方便地组织和管理多个测试用例。
JUnit还支持参数化测试和测试模板,提高了测试的灵活性和可维护性。
02
白盒测试法通常在软件开发过程 中,特别是在编码阶段进行,以 便在早期发现和修复潜在的错误 和缺陷。
白盒测试法的目的
01
02
03
验证代码的正确性
白盒测试法通过检查代码 的逻辑和结构,验证代码 是否符合设计要求,是否 能够正确实现功能。
提高代码质量
通过白盒测试,可以发现 代码中的缺陷和错误,并 及时修复,从而提高代码 的质量和稳定性。
《白盒测试法》ppt课件
目 录
• 白盒测试法简介 • 白盒测试法的主要技术 • 白盒测试法的实施步骤 • 白盒测试法的工具 • 白盒测试法的优缺点 • 白盒测试法的案例分析
01
白盒测试法简介
白盒测试法的定义
01
白盒测试法是一种软件测试方法 ,它要求测试人员对被测软件的 内部结构和工作原理有深入的了 解。
测试到。
循环覆盖
软件测试教学PPT-白盒测试
逻辑覆盖法
路径覆盖 寻找程序地路径地方法 单个判断语句地路径计算 单个循环语句地路径计算 有嵌套判断或循环时地路径计算
基本路径法
基本路径测试法是在程序控制流图地基 本上,通过分析控制构造地环路复杂,导 出基本可执行地路径集合,从而设计测 试用例地方法。
在基本路径测试,设计出地测试用例要 保证在测试程序地每条可执行语句至少 执行一次。
需求使用程序地控制流图行可视化表达。
基本路径法
程序地控制流图 是描述程序控制流地一种图示方法。其,
圆圈称为控制流图地一个结点,表示一个 或多个无分支地语句或源程序语句;箭头 称为边或连接,代表控制流。 在将程序流程图简化成控制流图时,应注 意: 在选择或多分支结构,分支地汇聚处应有 一个汇聚结点; 边与结点圈定地区域叫做区域,当对区域 计数时,图形外地区域也应记为一个区域。
基本路径法
程序地控制流图
基本路径法
环路复杂度 环路复杂度是一种为程序逻辑复杂提供定
量测度地软件度量 有以下三种方法用于计算环路复杂度: 流图区域地数量对应于环路地复杂度; 给定流图G地环路复杂度V(G),定义为
V(G)=E-N+二,其E是流图边地数量,N是流 图结点地数量; 给定流图G地环路复杂度V(G),定义为 V(G)=P+一,其P是流图G判定结点地数量。
T一,T二,-T三,T四 一,七
T一,-T二,T三,T四 二,五
-T一,T二,-T三,-T四 -T一,-T二,-T三,-T
四
T一,T二,T三,-T四
白盒测试及用例设计ppt课件
• 穷举途径测试不能够查出程序由于脱漏途径而出错。 • 穷举途径测试发现不了一些与数据相关的错误。
白盒测试方法〔续〕
• 采用白盒测试方法必需遵照以下几条原那么,才干到达测 试的目的:
• 保证一个模块中的一切独立途径至少被测试一次。 • 一切逻辑值均需测试真 (true) 和假 (false) 两种情况。 • 检查程序的内部数据构造,保证其构造的有效性。 • 在上下边境及可操作范围内运转一切循环。 • 白盒测试主要是检查程序的内部构造、逻辑、循环和途径
求实现的功能之间的比例关系。 • 构造覆盖率包括语句覆盖率、分支覆盖率、循环覆盖率、
途径覆盖率等等。
4.3.2 逻辑覆盖法
• 根据覆盖目的的不同,逻辑覆盖又可分为语句覆盖、断定覆 盖、条件覆盖、断定/条件覆盖、组合覆盖和途径覆盖。
• 语句覆盖:选择足够多的测试用例,使得程序中的每个可执 行语句至少执行一次。
断定覆盖〔续〕
阐明:以上仅思索了两出口的判别,我们还应把断定覆盖准
那么扩展到多出口判别〔如Case语句〕的情况。因此,断定 覆盖更为广泛的含义应该是使得每一个断定获得每一种能够 的结果至少一次。
6
2
7
1
5
10
3
8
4
9
条件覆盖
• 在实践程序代码中,一个断定中通常都包含假设干条件。条 件覆盖的目的是设计假设干测试用例,在执行被测程序后, 要使每个断定中每个条件的能够值至少满足一次。
• 根据断定/条件覆盖的根本思想,只需设计以下两个测试 用例便可以覆盖4个条件的8种取值以及4个断定分支。
测试用例 执行路径
x=4、y=6、z=5 abd
《软件白盒测试》课件
03 白盒测试的常用技术
代码覆盖技术
添加项标题
语句覆盖:确保每个语句都被执行至少一次
添加项标题
判定覆盖:确保每个判定(if、else、switch等)都被执行至少一次
添加项标题
条件覆盖:确保每个判定中的每个条件都被执行至少一次
添加项标题
路径覆盖:确保程序中的每个路径都被执行至少一次
添加项标题
循环覆盖:确保每个循环都被执行至少一次,包括循环体和循环条件
软件白盒测试
,
汇报人:
目录 /目录
01
点击此处添加 目录标题
04
白盒测试的实 践过程
02
软件白盒测试 概述
05
白盒测试的优 缺点
03
白盒测试的常 用技术
06
白盒测试工具 介绍
01 添加章节标题
02 软件白盒测试概述
定义和概念
软件白盒测试: 一种软件测试方 法,通过分析程 序的内部结构和 逻辑,验证程序 的正确性和完整 性。
感谢您的观看
汇报人:
添加项标题
数据流覆盖:确保程序中的数据流都被执行至少一次,包括输入、输出和内部数据流
路径覆盖技术
定义:通过执行所有可能的路径来测试软件 优点:能够全面覆盖软件的所有路径,提高测试覆盖率 缺点:需要大量的测试数据,可能导致测试时间过长 应用场景:适用于逻辑复杂的软件系统,如操作系统、数据库管理系统等
析和改进
测试用例设计
确定测试目标:明确测试的目的和范 围
设计测试用例:根据测试目标设计测 试用例
执行测试用例:按照测试用例执行测 试
记录测试结果:记录测试过程中的异 常情况和测试结果
分析测试结果:分析测试结果,找出 问题所在
软件工程白盒测试
白盒测试白盒测试以程序的结构为依据,所有又称为结构测试;早期的白盒测试把注意力放在流程图的各个判定框,使用不同的逻辑覆盖标准来表达对程序进行测试的详尽程度;随着测试技术的发展,人们越来越重视对程序执行路径的考察,并且用程序图代替流程图来设计测试用例;为了区分这两种白盒测试技术,以下把前者称为逻辑覆盖测试,后者称为路径测试;一、逻辑覆盖测试逻辑覆盖测试法Logic Coverage Testing考察的重点是图中的判定框菱形框;因为这些判定若不是与选择结构有关,就是与循环结构有关,是决定程序结构的关键成分;按照对被测程序所作测试的有效程度,逻辑覆盖测试可由弱到强区分为5种覆盖标有一个程序段如下:(a)L1a->c->e 上,;L1a-=,语句覆盖是最弱的逻(b),使得程序中每个判断的取真分支和取假分支至少经历一次;判定覆盖又称为分支覆盖;如上例如果选择路径L1a->c->e和L2a->b->d,可得满足要求得测试用例:L2a->b->d={A<=1 or B≠0 } and {A≠2 and x<=1}= A<=1 and x<=1 or { B≠0 and A≠2 and x<=1}测试用例可以设计为:2,0,4,2,0,3覆盖aceL11,1,1,1,1,1覆盖abdL2如果选取路径L3a->b->e和L4a->c->dL3a->b->e={A<=1 or B≠0 } and {A=2 or x>1}={ A<=1 and x>1} or { B≠0 and A=2 } or { B≠0 and x>1}L4a->c->d={A>1 and B=0 } and {A≠2 and x/A<=1}还可以得到另一组可用得测试用例:2,1,1,2,1,2覆盖abeL33,0,3,3,1,1覆盖acdL4所有测试用例得取法不唯一;注意有例外情况,例如,如果把上例中第二个判定中的条件x>1错写成x<1,那么利用上面两组测试用例,仍能得到同样的结果;这表明,只是判定覆盖,还不能保证一定能查出在判断得条件中存在得错误;因此还需要更强的逻辑覆盖准则检验判断内部条件;(c)条件覆盖所谓条件覆盖就是设计若干个测试用例,运行被测程序,使得程序中每个判断的每个条件的可能取值至少执行一次;上例中,我们事先可对所有条件得取值加以标记;例如:对于第一个判断:条件A>1取真值为T1,取假值为T1条件B=1取真值为T2,取假值为T2对于第二个判断:条件A=2取真值为T3,取假值为T3条件x>1取真值为T4,取假值为T4断中所有条件得可能取值;但是后一组测试用例虽满足了条件覆盖,但只覆盖了第一个判断得取假分支和第二个判断得取真分支,不满足判定覆盖得要求;为了解决这一矛盾,需要对条件和分支兼顾,有必要考虑以下得判定-条件覆盖;(d)判定-条件覆盖所谓判定-条件覆盖就是设计足够的测试用例,使得判断中每个条件得所有可能取值至少执行一次,同时每个判断本身的所有可能判断结果至少执行一次;上例中可,但是事实并非如此;因为往往某些条件掩盖了另一些条件;对于条件表达式A>1and B=0来说,若A>1的测试结果为真,则还有测试B=0,才能决定表达式得值;而若A>1的测试结果为假,可以立刻确定表达式得结果为假;这时往往就不再测试B=0的取值了;因此,条件B=0就没有检查;同样,对于条件表达式A=2or X>1来说,若A=2得测试结果为真,就可以立即确定表达式的结果为真;这时,条件X>1就没有检查;因此,采用判定-条件覆盖,逻辑表达式中的错误不一定能够查得出来;(e)条件组合覆盖所谓条件组合覆盖就是设计足够得测试用例,运行被测程序,使得每个判断得所有可能得条件取值组合至少执行一次;上例中,先对各个判断得条件取值组合加以标记;如下:记① A>1,B=0 作T1 T2,属第一个判断得取真分支;② A>1,B≠0 作T1 T2,属第一个判断得取假分支;③ A≯1,B=0 作T1 T2,属第一个判断得取假分支;④ A≯1,B≠0 作T1 T2,属第一个判断得取假分支;⑤ A=2,x>1 作T3 T4,属第二个判断得取真分支;⑥ A=2,x≯1 作T3 T4,属第二个判断得取真分支;⑦ A≠2,x>1 作T3 T4,属第二个判断得取真分支;⑧ A≠2,x≯1 作T3 T4,属第二个判断得取假分支;,但路径漏掉了L4;测试还不完全;六种白盒子测试方法:语句覆盖、判定覆盖、条件覆盖、判定条件覆盖、条件组...白盒测试的概述由于逻辑错误和不正确假设与一条程序路径被运行的可能性成反比;由于我们经常相信某逻辑路径不可能被执行, 而事实上,它可能在正常的情况下被执行;由于代码中的笔误是随机且无法杜绝的,因此我们要进行白盒测试;白盒测试又称结构测试,透明盒测试、逻辑驱动测试或基于代码的测试;白盒测试是一种测试用例设计方法,盒子指的是被测试的软件,白盒指的是盒子是可视的,你清楚盒子内部的东西以及里面是如何运作的;白盒的测试用例需要做到:·保证一个模块中的所有独立路径至少被使用一次·对所有逻辑值均需测试 true 和 false·在上下边界及可操作范围内运行所有循环·检查内部数据结构以确保其有效性白盒测试的目的:通过检查软件内部的逻辑结构,对软件中的逻辑路径进行覆盖测试;在程序不同地方设立检查点,检查程序的状态,以确定实际运行状态与预期状态是否一致;白盒测试的特点:依据软件设计说明书进行测试、对程序内部细节的严密检验、针对特定条件设计测试用例、对软件的逻辑路径进行覆盖测试;白盒测试的实施步骤:1.测试计划阶段:根据需求说明书,制定测试进度;2.测试设计阶段:依据程序设计说明书,按照一定规范化的方法进行软件结构划分和设计测试用例;3.测试执行阶段:输入测试用例,得到测试结果;4.测试总结阶段:对比测试的结果和代码的预期结果,分析错误原因,找到并解决错误;白盒测试的方法:总体上分为静态方法和动态方法两大类;静态分析是一种不通过执行程序而进行测试的技术;静态分析的关键功能是检查软件的表示和描述是否一致,没有冲突或者没有歧义;动态分析的主要特点是当软件系统在模拟的或真实的环境中执行之前、之中和之后 , 对软件系统行为的分析;动态分析包含了程序在受控的环境下使用特定的期望结果进行正式的运行;它显示了一个系统在检查状态下是正确还是不正确;在动态分析技术中,最重要的技术是路径和分支测试;下面要介绍的六种覆盖测试方法属于动态分析方法;黑盒测试black—box testing又称功能测试、数据测试或基于规范的测试;用这种方法进行测试时,被测程序被当作看不见内部的黑盒;在完全不考虑程序内部结构和内部特性的情况下,测试者仅依据程序功能的需求规范考虑确定测试用例和推断测试结果的正确性;因此黑盒测试是从用户观点出发的测试,黑盒测试直观的想法就是既然程序被规定做某些事,那我们就看看它是不是在任何情况下都做的对;完整的“任何情况”是无法验证的,为此黑盒测试也有一套产生测试用例的方法,以产生有限的测试用例而覆盖足够多的“任何情况”;由于黑盒测试不需要了解程序内部结构,所以许多高层的测试如确认测试、系统测试、验收测试都采用黑盒测试;黑盒测试首先是程序通常的功能性测试;要求:每个特性必须被一个测试用例或一个被认可的异常所覆盖;用数据类型和数据值的最小集测试;用一系列真实的数据类型和数据值运行,测试超负荷、饱和及其他“最坏情况”的结果;用假想的数据类型和数据值运行,测试排斥不规则输入的能力;对影响性能的关键模块,如基本算法、应测试单元性能包括精度、时间、容量等;不仅要考核“程序是否做了该做的”还要考察“程序是否没做不该做的2”同时还要考察程序在其他一些情况下是否正常;这些情况包括数据类型和数据值的异常等等;下述几种方法:a等价类划分,b因果图方法,c边值分析法,d猜错法,e随机数法,就是从更广泛的角度来进行黑盒测试;每一个方法都力图能涵盖更多的“任何情况”,但又各有长处,综合使用这些方法,会得到一个较好的测试用例集;1.等价类划分等价类划分是一种典型的黑盒测试方法;等价类是指某个输入域的集合;它表示对揭露程序中的错误来说,集合中的每个输入条件是等效的;因此我们只要在一个集合中选取一个测试数据即可;等价类划分的办法是把程序的输入域划分成若干等价类,然后从每个部分中选取少数代表性数据当作测试用例;这样就可使用少数测试用例检验程序在一大类情况下的反映;在考虑等价类时,应该注意区别以下两种不同的情况:有效等价类:有效等价类指的是对程序的规范是有意义的、合理的输入数据所构成的集合;在具体问题中,有效等价类可以是一个,也可以是多个;无效等价类:无效等价类指对程序的规范是不合理的或无意义的输入数据所构成的集合;对于具体的问题,无效等价类至少应有一个,也可能有多个;确定等价类有以下几条原则:如果输入条件规定了取值范围或值的个数,则可确定一个有效等价类和两个无效等价类;例如,程序的规范中提到的输入条包括“……项数可以从1到999……”,则可取有效等价类为“l考项数<999”,无效等价类为“项数<l,,及“项数>999”;输入条件规定了输入值的集合,或是规定了“必须如何”的条件,则可确定一个有效等价类和一个无效等价类;如某程序涉及标识符,其输入条件规定“标识符应以字母开头……”则“以字母开头者”作为有效等价类,“以非字母开头”作为无效等价类;如果我们确知,已划分的等价类中各元素在程序中的处理方式是不同的,则应将此等价类进一步划分成更小等价类;输入条件有效等价类无效等价类;;;;;;;;;;;; ;;;;;;;;;;;; ;;;;;;;;;;;;根据已列出的等价类表,按以下步骤确定测试用例:为每个等价类规定一个唯一的编号;设计一个测试用例,使其尽可能多地覆盖尚未覆盖的有效等价类;重复这一步,最后使得所有有效等价类均被测试用例所覆盖;设计一个新的测试用例,使其只覆盖一个无效等价类;重复这一步,使所有无效等价类均被覆盖;这里强调每次只覆盖一个无效等价类;这是因为一个测试用例中如果含有多个缺陷,有可能在测试中只发现其中的一个,另一些被忽视;等价类划分法能够全面、系统地考虑黑盒测试的测试用例设计问题,但是没有注意选用一些“高效的”、“有针对性的”测试用例;后面介绍的边值分析法可以弥补这一缺点;2.因果图等价类划分法并没有考虑到输入情况的各种组合;这样虽然各个输入条件单独可能出错的情况已经看到了,但多个输入情况组合起来可能出错的情况却被忽略;采用因果图方法能帮助我们按一定步骤选择一组高效的测试用例,同时,还能为我们指出程序规范的描述中存在什么问题;利用因果图导出测试用例需要经过以下几个步骤:分析程序规范的描述中哪些是原因,哪些是结果;原因常常是输入条件或是输入条件的等价类;结果是输出条件;分析程序规范的描述中语义的内容,并将其表示成连接各个原因与各个结果的“因果图”;由于语法或环境的限制,有些原因和结果的组合情况是不可能出现的;为表明这些特定的情况,在因果图上使用持殊的符号标明约束条件;把因果图转换成判定表;把判定表的每一列写成一个测试用例;3.边值分析法边值分析法是列出单元功能、输入、状态及控制的合法边界值和非法边界值,设计测试用例,包含全部边界值的方法;典型地包括IF语句中的判别值,定义域、值域边界,空或畸形输入,末受控状态等;边值分析法不是一类找一个例子的方法,而是以边界情况的处理作为主要目标专门设计测试用例的方法;另外,边值分析不仅考查输入的边值,也要考虑输出的边值;这是从人们的经验得出的一种有效方法;人们发现许多软件错误只是在下标、数据结构和标量值的边界值及其上、下出现,运行这个区域的测试用例发现错误的概率很高;用边值分析法设计测试用例时,有以下几条原则:如果输入条件规定了取值范围,或是规定了值的个数,则应以该范围的边界内及刚刚超出范围的边界外的值,或是分别对最大、最小及稍小于最小、稍大于最大个数作为测试用例;如有规范“某文件可包含l至255”个记录……“,则测试用例可选1和255及0和256等;针对规范的每个输出条件使用原则〔a〕;如果程序规范中提到的输入或输出域是个有序的集合如顺序文件、表格等就应注意选取有序集的第一个和最后一个元素作为测试用例;分析规范,尽可能找出可能的边界条件;一个典型的边值分析例子是三角形分类程序;选取a,b,c构成三角形三边,“任意两边之和大于第三边”为边界条件;边值分析相等价类划分侧重不同,对等价类划分是一个补充;如上述三角形问题,选取a=3,b=4,c=5,a=2,b=4,c=7则覆盖有效和无效等价类;如果能在等价类划分中注入边值分析的思想;在每个等价类中不只选取一个覆盖用例,而是进而选取该等价类的边界值等价类划分法将更有效,最后可以用边值分析法再补充一些测试用例;4.猜错法猜错法在很大程度上是凭经验进行的,是凭人们对过去所作的测试工作结果的分析,对所揭示的缺陷的规律性作直觉的推测来发现缺陷的;一个采用两分法的检索程序,典型地可以列出下面几种测试情况:被检索的表只有一项或为空表;表的项数恰好是2的幂次;表的项数比2的幂次多1等;猜错法充分发挥人的经验,在一个测试小组中集思广益,方便实用,特别在软件测试基础较差的情况下,很好地组织测试小组也可以有外来人员进行错误猜测,是有效的测试方法;5.随机数法即测试用例的参数是随机数;它可以自动生成,因此自动化程度高;使用大量随机测试用例测试通过的程序会提高用户对程序的信心;但其关键在于随机数的规律是否符合使用实际;。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
a >1 || c < 1 T 4
6} 7 c = b+c;
F 5
c=b+c
c=c/a c=c+1
输出:3.5 -2
5. 条件组合覆盖准则
设计足够的测试用例,使得判定中每个条件的所有 可能组合至少出现一次,并且每个判定结果也至少 出现一次。
7.6 白盒测试技术
白盒测试 的原则
对程序模块的所有独立 执行路径至少测试一次
对所有的逻辑判定取 “真”与取“假”的两种情况
都至少测试一次。
在循环的边界和可操作范围 内执行循环体
测试内部数据结构的有效性, 完成边界条件的测试。
执行路径:520个
循
环
近似为1014个
小
于
等 于
如果1ms完成一
20
个测试
No
测试用例
覆盖的判断条件
通过路径
1 a=2,b= -1,c= -2
T1,F2,T3,F4
?
2 A=-1,b=2,c= 3
F1,T2,F3,T4
?
虽然覆盖了所有条件,但不能保证多个判定 分支均被覆盖到
4、 判定—条件覆盖准则
设计足够测试用例,使得判定中的所有条件可 能取值至少执行一次,同时,所有判定的可能 结果至少执行一次。
值为假分支
条件中的取值有 被忽略的情况
a=2,b=1,c=3 a= -2,b=1,c= -3
a >0 && b > 0 T
c=c/a
判定覆盖仍是弱覆 盖标准!
F a >1 || c < 1 T
c=c+1
Bug
F c=b+c
输出:3.5 -2
3. 条件覆盖准则 设计测试用例,使得每个判断中每个条
c = c / a; } if ( a >1 || c > 1 ){
c= c+1; } c = b+c;
M a >0 && b > 0 T
F
N a >1 || c > 1 T
F
c=b+c
c=c/a c=c+1
M=.T. 且 N=.T. M=.F. 且 N=.F.
1
M a >0 && b > 0 T 2
c=c+1
F 5
c=b+c
P1:1-2-4 P2:1-2-5
P3:1-3-4
P4:1-3-5
测试用例集
对于判定M: 条件a>0:取值为真为T1,取值为假为F1 条件b>0:取值为真为T2,取值为假为F2 对于判定N: 条件a>1:取值为真为T3,取值为假为F3 条件c>1:取值为真为T4,取值为假为F4
× Case1 2 0 3 √ Case2 2 1 3
a >0 && b > 0 T F
a >1 || c > 1 T F c=b+c
c=c/a c=c+1
Case2输出:c=3.5
思考:
Case2:a=2, b=1, c=3
如果M为:a >0 || b > 0; N为:a >1&&c > 1,
M a >0 || b > 0
次
需3170年
迪杰斯特拉定律:穷尽测试永远不可能
一、 逻辑覆盖 1. 语句覆盖 2. 判定覆盖 3. 条件覆盖 4. 判定-条件覆盖 5. 条件组合覆盖 6. 路径覆盖
1. 语句覆盖 设计测试用例,使被测程序中的每个
可执行语句至少被执行一次
例题
int a, b; double c; if ( a >0 && b > 0 ){
c = c / a; } if ( a >1 || c > 1 ){
c= c+1; } c = b+c;
a >0 && b > 0 T F
a >1 || c > 1 T F c=b+c
c=c/a c=c+1
M=.T. 且 N=.T.
M
a >0 && b > 0 T
F
N
a >1 || c > 1 T
条件M取值为假分支 条件N取值为假分支
路径 P1
P4
判定—条件覆盖准则的不足
a=2,b=1,c=3 a= -2,b=1,c= -3
1
int a, b; double c
1 if ( a >0 && b > 0 ){
2 c = c / a;
3}
Bug
a >0 && b > 0 T 2
F 3
4 if ( a >1 || c <1 ){ 5 c= c+1;
判定-条件覆盖能同时满足判定、条件两种覆盖 标准。
例题
int a, b; double c if ( a >0 && b > 0 ){
c = c / a; } if ( a >1 || c > 1 ){
c= c+1; } c = b+c;
1
M a >0 && b > 0 T 2 c=c/a
F 3
F
c=b+c
c=c/a c=c+1
Case1:a=2, b此=语0,句c=未3覆盖
用例 a b c
× Case1 2 0 3
Case2 2 1 3
a >0 && b > 0 T F
a >1 || c > 1 T F c=b+c
c=c/a c=c+1
Case2输入:a=2, b=1, c=3
用例 a b c
件 double c if ( a >0 && b > 0 ){
c = c / a; } if ( a >1 || c > 1 ){
c= c+1; } c = b+c;
M a >0 && b > 0 T 2
F 3
c=c/a
N a >1 || c > 1 T 4
N a >1 || c > 1 T 4
F 5 c=b+c
c=c+1
测试用例集
为了使被测程序得到充分测试,不仅每个条件需要 被覆盖,而且每个条件的组合也应该被覆盖到。
No
测试用例
覆盖的判断分支
判定条件
1 a=2,b= 1,c= 3 T1,T2,T3,T4 条件M取值为真分支 条件N取值为真分支
2 a= -1,b= -2,c= -5 F1,F2,F3,F4
Bug
T
c=c/a
测试用例与测试结果有设么 F
变化?
N a >1 && c > 1 T
F
c=c+1
c=b+c
Bug
语句C覆as盖e2是输出弱:覆c盖=3标.5 准!
2. 判定覆盖准则
设计测试用例,使被测程序中的每个判断的 取真分支和取假分支都被测试用例至少执行 一次
例题
int a, b; double c if ( a >0 && b > 0 ){
F 3
N a >1 || c > 1 T 4
F 5 c=b+c
c=c/a c=c+1
设计测试用例及预期结果
测试用例
No
测试用例
覆盖的判断分支
输出结果
1 a=2,b=1,c=3 判断M取值为真分支和判断N取 值为真分支
c=3.5
2 a= -2,b=1,c= -3 判断M取值为假分支和判断N取
c=-2