软件测试计划与测试用例设计说明

上传人:xmg****18 文档编号:114693823 上传时间:2019-11-12 格式:PPT 页数:35 大小:1.32MB
返回 下载 相关 举报
软件测试计划与测试用例设计说明_第1页
第1页 / 共35页
软件测试计划与测试用例设计说明_第2页
第2页 / 共35页
软件测试计划与测试用例设计说明_第3页
第3页 / 共35页
软件测试计划与测试用例设计说明_第4页
第4页 / 共35页
软件测试计划与测试用例设计说明_第5页
第5页 / 共35页
点击查看更多>>
资源描述

《软件测试计划与测试用例设计说明》由会员分享,可在线阅读,更多相关《软件测试计划与测试用例设计说明(35页珍藏版)》请在金锄头文库上搜索。

1、软件测试计划与测试用例设计,2005 年 7 月,2,目录,软件测试计划概述 测试计划的内容详解 测试用例概述 什么是测试用例 为什么需要测试用例 良好测试用例的特征 测试用例的组成元素与范例 白盒测试用例设计方法 等价类测试用例设计方法 边界值测试用例设计方法 错误推测法测试用例设计 因果图法测试用例设计 测试类型与测试用例设计 设计测试用例的策略选择 测试用例设计工具 案例研究:黑盒测试用例设计,3,软件测试计划概述,测试计划的定义 一个叙述了预定的测试活动的范围、途径、资源及进度安排的文档。它确认了测试项、被侧特征、测试任务、人员安排、以及任何偶发计划的风险。 ANSI/IEEE软件测试

2、文档标准829-1983,测试计划的作用 为测试过程提供指导 测试目标 测试内容 测试方法 测试时间周期 改善测试任务与测试过程的关系 提高测试的组织、规划和管理能力,测试计划的内容 测试项目简介 测试项 需要测试的特征 不需要测试的特征 测试的方法 (测试人员、测试工具、测试流程) 测试开始条件和结束条件 测试提交的结果与格式 测试环境(软件、硬件、网络) 测试者的任务、联系方式与培训 测试进度与跟踪方式 测试风险与解决方式 本测试计划的审批与变更方式,4,测试计划的内容详解,测试项目简介 归纳所要求测试的软件项和软件特性,可以包括系统目标、背景、范围及引用材料等。 在最高层测试计划中,如果

3、存在下述文件,则需要引用它们:项目计划、质量保证计划、有关的政策、有关的标准等。 测试项 描述被测试的对象,包括其版本、修订级别,并指出在测试开始之前对逻辑或物理变换的要求。 被测试的特性 指明所有要被测试的软件特性及其组合,指明每个特性或特性组合有关的测试设计说明。 不被测试的特性 指出不被测试的所有特性和特性的有意义的组合及其理由。,5,测试计划的内容详解(续1),测试方法 描述测试的总体方法,规定测试指定特性组志需的主要活动、所需的时间。 规定所希望的测试程度,指明用于判断测试彻底性的技术(如:检查哪些语句至少执行过一次)。 指出对测试的主要限制,例如:测试项可用性、测试资源的可用性和测

4、试截止期限等。 开始条件和结束条件 规定各测试项的开始测试需要满足的条件 测试通过和测试结束的条件。 测试环境 测试的操作系统和需要安装的辅助测试工具(来源与参数设置) 软件、硬件和网络环境设置,6,测试计划的内容详解(续2),测试者的任务、联系方式与培训 测试成员的名称、任务、电话、电子邮件等联系方式 为完成测试需要进行的项目课程培训 测试进度与跟踪方式 在软件项目进度中规定的测试里程碑以及所有测试项传递时间。 定义所需的新的测试里程碑,估计完成每项测试任务所需的时间,为每项测试任务和测试里程碑规定进度,对每项测试资源规定使用期限。 报告和跟踪测试进度的方式:每日报告、每周报告;书面报告、电

5、话会议 测试风险与解决方式 预测测试计划中的风险 规定对各种风险的应急措施(延期传递的测试项可能需要加班、添加测试人员、减少测试内容。) 测试计划的审批和变更方式 审批人和生效方式 如何处理测试计划的变更,7,测试用例概述,如何以最少的人力、资源投入,在最短的时间内完成测试,发现软件系统的缺陷,保证软件的优良品质,则是软件公司探索和追求的目标。 测试用例是测试工作的指导,是软件测试的必须遵守的准则。更是软件测试质量稳定的根本保障。,8,什么是测试用例,测试用例的定义 测试内容的一系列情景和每个情景中必须依靠输入和输出,而对软件的正确性进行判断的测试文档,称为测试用例。 测试用例就是将软件测试的

6、行为活动,做一个科学化的组织归纳。,9,为什么需要测试用例,在开始实施测试之前设计好测试用例,避免盲目测试并提高测试效率,减少测试的不完全性; 测试用例的使用令软件测试的实施重点突出、目的明确; 根据测试用例的多少和执行难度,估算测试工作量,便于测试项目的时间和资源管理与跟踪; 减少回归测试的复杂程度 在软件版本更新后只需修正少量的测试用例便可展开测试工作,降低工作强度、缩短项目周期; 功能模块的测试用例的通用化和复用化则会使软件测试易于开展,并随着测试用例的不断细化其效率也不断攀升; 根据测试用例的操作步骤和执行结果,可以方便地书写软件测试缺陷报告; 可以根据测试用例的执行等级,实施不同级别

7、的测试; 为分析软件缺陷和程序模块质量提供依据; 便于大型软件测试项目外包测试指导基础; 总结: 软件测试是有组织性、步骤性和计划性的,为了能将软件测试的行为转换为可管理的、具体量化的模式,需要创建和维护测试用例。,10,良好测试用例的特征,可以最大程度地找出软件隐藏的缺陷 可以最高效率的找出软件缺陷 可以最大程度地满足测试覆盖要求 既不过分复杂、也不能过分简单 使软件缺陷的表现可以清楚的判定 测试用例包含期望的正确的结果 待查的输出结果或文件必须尽量简单明了 不包含重复的测试用例 测试用例内容清晰、格式一致、分类组织,11,测试用例的组成元素与范例,测试用例编号ID 测试用例标题 测试的模块

8、,测试输入条件 期望的输出结果 其它说明,12,白盒测试用例设计方法,什么是白盒测试 白盒测试也称为结构测试,把程序看作一个透明的盒子,测试程序的代码书写结构和逻辑问题 白盒测试用例的设计方法 逻辑覆盖:以程序的内部逻辑结构为基础,分为语句覆盖、判定覆盖、判定-条件覆盖、条件组合覆盖等 基本路径测试:在程序控制流程的基础上,分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例。 白盒测试用例注意事项 由于测试路径可能非常多,由于时间和资源问题,选出足够多的路径测试 由于深入到程序编码,通常开发人员协助测试人员书写白盒测试用例,13,等价类测试用例设计方法,什么是黑盒测试 白盒测试

9、也称为功能测试,把程序看作一个不透明的盒子,测试程序的功能。 黑盒测试用例的设计方法 等价类划分: 在分析需求规格说明的基础上划分等价类,列出等价类表。 将程序可能的输入数据分成若干个子集,从每个子集选取一个代表性的数据作为测试用例,等价类是某个输入域的子集,在该子集中每个输入数据的作用是等效的。 等价类的分类:有效等价类和无效等价类。有效等价类是有意义的、合理的输入数据,可以检查程序是否实现了规格说明中所规定的功能和性能。无效等价类与有效等价类的意义相反。 设计测试用例时,要同时考虑这两种等价类。因为软件不仅要能接收合理的数据,也要能经受意外的考验。这样的测试才能确保软件具有更高的可靠性。,

10、14,确定等价类的方式,在输入条件规定了取值范围或值的个数的情况下,则可以确立一个有效等价类和两个无效等价类。 在输入条件规定了输入值的集合或者规定了“必须如何”的条件的情况下,可以确立一个有效等价类和一个无效等价类。 在输入条件是一个布尔量的情况下,可确定一个有效等价类和一个无效等价类。 在规定了输入数据的一组值(假定n个),并且程序要对每一个输入值分别处理的情况下,可确立n个有效等价类和一个无效等价类。 在规定了输入数据必须遵守的规则的情况下,可确立一个有效等价类(符合规则)和若干个无效等价类(从不同角度违反规则)。,15,根据等价类创建测试用例的步骤,建立等价类表,列出所有划分出的等价类

11、:,为每个等价类规定一个唯一的编号; 设计一个新的测试用例,使其尽可能多地覆盖尚未覆盖的有效等价类。重复这一步,最后使得所有有效等价类均被测试用例所覆盖; 设计一个新的测试用例,使其只覆盖一个无效等价类。重复这一步使所有无效等价类均被覆盖。,16,边界值测试用例设计方法,边界值分析法: 程序的很多错误发生在输入或输出范围的边界上,因此针对各种边界情况设置测试用例,可以发现不少程序缺陷。 设计方法: 确定边界情况(输入或输出等价类的边界) 选取正好等于、刚刚大于或刚刚小于边界值作为测试数据,17,确定边界值的方式,如果输入条件规定了值的范围,则应取刚达到这个范围的边界的值,以及刚刚超越这个范围边

12、界的值作为测试输入数据。 如果输入条件规定了值的个数,则用最大个数、最小个数、比最小个数少一、比最大个数多一的数作为测试数据。 如果程序的规格说明给出的输入域或输出域是有序集合,则应选取集合的第一个元素和最后一个元素作为测试用例。 如果程序中使用了一个内部数据结构,则应当选择这个内部数据结构的边界上的值作为测试用例。 分析规格说明,找出其他可能的边界条件。,18,错误推测法测试用例设计,基于经验和直觉推测程序中所有可能存在的各种错误,从而有针对性地设计测试用例。 发现程序经常出现的错误的方法: 单元测试中发现的模块错误; 产品的以前版本曾经发现的错误; 输入数据为0或字符为空; 当软件要求输入

13、时(比如在文本框中),不是没有输入正确的信息,而是根本没有输入任何内容,单单按了Enter键; 这种情况在产品说明书中常常忽视,程序员也可能经常遗忘,但是在实际使用中却时有发生。程序员总会习惯性的认为用户要么输入信息,不管是看起来合法的或非法的信息,要不就会选择Cancel键放弃输入,,19,测试场景法设计测试用例,现在的软件几乎都是用事件触发来控制流程的,事件触发时的情景便形成了场景,而同一事件不同的触发顺序和处理结果就形成事件流。这种在软件设计方面的思想也可引入到软件测试中,可以比较生动地描绘出事件触发时的情景,有利于测试设计者设计测试用例,同时使测试用例更容易理解和执行。,20,因果图法

14、测试用例设计,多种输入条件的组合,产生多种结果设计测试用例。 设计方法: 分析软件规格说明文档描述的哪些是原因(输入条件),哪些是结果(输出条件),给每个原因和结果赋予一个标示符。 找出原因与结果,原因与原因之间的对应关系,划出因果图 在因果图上标上哪些不可能发生的因果关系,表明约束或限制条件 根据因果图,创建判定表,将复杂的逻辑关系和多种条件组合很具体明确的表示出来 把判定表的每一行作为依据设计测试用例。,21,测试类型与测试用例设计,根据测试类型设计,根据程序功能模块设计,功能测试,易用性测试,配置测试,压力测试,回归测试,界面测试,文档测试,国际化测试,测试用例1 测试用例2 测试用例3

15、,测试用例1 测试用例2 测试用例3,安装/卸载测试,联机帮助测试,软件更新测试,联机注册测试,文件操作测试,测试用例1 测试用例2 测试用例3,测试用例1 测试用例2 测试用例3,数据备份测试,22,设计测试用例的策略选择,测试用例的设计方法不是单独存在的,具体到每个测试项目里都会用到多种方法,每种类型的软件有各自的特点,每种测试用例设计的方法也有各自的特点,针对不同软件如何利用这些黑盒方法是非常重要的。 在实际测试中,往往是综合使用各种方法才能有效提高测试效率和测试覆盖度,这就需要认真掌握这些方法的原理,积累更多的测试经验,以有效提高测试水平。 首先进行等价类划分,包括输入条件和输出条件的

16、等价划分,将无限测试变成有限测试,这是减少工作量和提高测试效率的最有效方法。 在任何情况下都必须使用边界值分析方法。经验表明用这种方法设计出测试用例发现程序错误的能力最强。 对照程序逻辑,检查已设计出的测试用例的逻辑覆盖程度。如果没有达到要求的覆盖标准,应当再补充足够的测试用例。 对于业务流清晰的系统,可以利用场景法贯穿整个测试案例过程,在案例中综合使用各种测试方法。,23,测试用例设计工具,设计依据: 软件需求文档 软件设计文档,通用设计工具: Microsoft Word Microsoft Excel Microsoft Access,设计工具专用: IBM Rational TestManager Mercury Interactive TestDirector,常见问题: 软件文档不全或没有文档 没有完成编码就开始设计测试用例,24,案例研究1:根据输入判断三角形的形状,测试场景: 一个程序读入3个整数,把这三个数值看作一个三角形的3条边的长度值。这个程序要打印出信息,说明这个三角形是不等边的、是等腰的、还是等边的。,确定输入数据与三角形形状的关系: 设三角

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号