《测试计划和测试案例分析.ppt》由会员分享,可在线阅读,更多相关《测试计划和测试案例分析.ppt(34页珍藏版)》请在三一办公上搜索。
1、软件测试计划与测试用例设计,Author:崔启亮(Gavin Cui)Email:MSN:,2005 年 7 月,2,目录,软件测试计划概述测试计划的内容详解测试用例概述什么是测试用例为什么需要测试用例良好测试用例的特征测试用例的组成元素与范例白盒测试用例设计方法等价类测试用例设计方法边界值测试用例设计方法错误推测法测试用例设计因果图法测试用例设计测试类型与测试用例设计设计测试用例的策略选择测试用例设计工具案例研究:黑盒测试用例设计,3,软件测试计划概述,测试计划的定义 一个叙述了预定的测试活动的范围、途径、资源及进度安排的文档。它确认了测试项、被侧特征、测试任务、人员安排、以及任何偶发计划的
2、风险。ANSI/IEEE软件测试文档标准829-1983,测试计划的作用 为测试过程提供指导 测试目标 测试内容 测试方法 测试时间周期 改善测试任务与测试过程的关系 提高测试的组织、规划和管理能力,测试计划的内容 测试项目简介 测试项 需要测试的特征 不需要测试的特征 测试的方法(测试人员、测试工具、测试流程)测试开始条件和结束条件 测试提交的结果与格式 测试环境(软件、硬件、网络)测试者的任务、联系方式与培训 测试进度与跟踪方式 测试风险与解决方式 本测试计划的审批与变更方式,4,测试计划的内容详解,测试项目简介 归纳所要求测试的软件项和软件特性,可以包括系统目标、背景、范围及引用材料等。
3、在最高层测试计划中,如果存在下述文件,则需要引用它们:项目计划、质量保证计划、有关的政策、有关的标准等。测试项描述被测试的对象,包括其版本、修订级别,并指出在测试开始之前对逻辑或物理变换的要求。被测试的特性指明所有要被测试的软件特性及其组合,指明每个特性或特性组合有关的测试设计说明。不被测试的特性指出不被测试的所有特性和特性的有意义的组合及其理由。,5,测试计划的内容详解(续1),测试方法描述测试的总体方法,规定测试指定特性组志需的主要活动、所需的时间。规定所希望的测试程度,指明用于判断测试彻底性的技术(如:检查哪些语句至少执行过一次)。指出对测试的主要限制,例如:测试项可用性、测试资源的可用
4、性和测试截止期限等。开始条件和结束条件规定各测试项的开始测试需要满足的条件测试通过和测试结束的条件。测试环境 测试的操作系统和需要安装的辅助测试工具(来源与参数设置)软件、硬件和网络环境设置,6,测试计划的内容详解(续2),测试者的任务、联系方式与培训 测试成员的名称、任务、电话、电子邮件等联系方式 为完成测试需要进行的项目课程培训 测试进度与跟踪方式 在软件项目进度中规定的测试里程碑以及所有测试项传递时间。定义所需的新的测试里程碑,估计完成每项测试任务所需的时间,为每项测试任务和测试里程碑规定进度,对每项测试资源规定使用期限。报告和跟踪测试进度的方式:每日报告、每周报告;书面报告、电话会议
5、测试风险与解决方式 预测测试计划中的风险 规定对各种风险的应急措施(延期传递的测试项可能需要加班、添加测试人员、减少测试内容。)测试计划的审批和变更方式 审批人和生效方式 如何处理测试计划的变更,7,测试用例概述,如何以最少的人力、资源投入,在最短的时间内完成测试,发现软件系统的缺陷,保证软件的优良品质,则是软件公司探索和追求的目标。测试用例是测试工作的指导,是软件测试的必须遵守的准则。更是软件测试质量稳定的根本保障。,8,什么是测试用例,测试用例的定义测试内容的一系列情景和每个情景中必须依靠输入和输出,而对软件的正确性进行判断的测试文档,称为测试用例。测试用例就是将软件测试的行为活动,做一个
6、科学化的组织归纳。,9,为什么需要测试用例,在开始实施测试之前设计好测试用例,避免盲目测试并提高测试效率,减少测试的不完全性;测试用例的使用令软件测试的实施重点突出、目的明确;根据测试用例的多少和执行难度,估算测试工作量,便于测试项目的时间和资源管理与跟踪;减少回归测试的复杂程度在软件版本更新后只需修正少量的测试用例便可展开测试工作,降低工作强度、缩短项目周期;功能模块的测试用例的通用化和复用化则会使软件测试易于开展,并随着测试用例的不断细化其效率也不断攀升;根据测试用例的操作步骤和执行结果,可以方便地书写软件测试缺陷报告;可以根据测试用例的执行等级,实施不同级别的测试;为分析软件缺陷和程序模
7、块质量提供依据;便于大型软件测试项目外包测试指导基础;总结:软件测试是有组织性、步骤性和计划性的,为了能将软件测试的行为转换为可管理的、具体量化的模式,需要创建和维护测试用例。,10,良好测试用例的特征,可以最大程度地找出软件隐藏的缺陷可以最高效率的找出软件缺陷可以最大程度地满足测试覆盖要求既不过分复杂、也不能过分简单使软件缺陷的表现可以清楚的判定测试用例包含期望的正确的结果待查的输出结果或文件必须尽量简单明了不包含重复的测试用例测试用例内容清晰、格式一致、分类组织,11,测试用例的组成元素与范例,测试用例编号ID测试用例标题测试的模块,测试输入条件期望的输出结果其它说明,12,白盒测试用例设
8、计方法,什么是白盒测试白盒测试也称为结构测试,把程序看作一个透明的盒子,测试程序的代码书写结构和逻辑问题白盒测试用例的设计方法逻辑覆盖:以程序的内部逻辑结构为基础,分为语句覆盖、判定覆盖、判定-条件覆盖、条件组合覆盖等基本路径测试:在程序控制流程的基础上,分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例。白盒测试用例注意事项由于测试路径可能非常多,由于时间和资源问题,选出足够多的路径测试由于深入到程序编码,通常开发人员协助测试人员书写白盒测试用例,13,等价类测试用例设计方法,什么是黑盒测试白盒测试也称为功能测试,把程序看作一个不透明的盒子,测试程序的功能。黑盒测试用例的设计
9、方法等价类划分:在分析需求规格说明的基础上划分等价类,列出等价类表。将程序可能的输入数据分成若干个子集,从每个子集选取一个代表性的数据作为测试用例,等价类是某个输入域的子集,在该子集中每个输入数据的作用是等效的。等价类的分类:有效等价类和无效等价类。有效等价类是有意义的、合理的输入数据,可以检查程序是否实现了规格说明中所规定的功能和性能。无效等价类与有效等价类的意义相反。设计测试用例时,要同时考虑这两种等价类。因为软件不仅要能接收合理的数据,也要能经受意外的考验。这样的测试才能确保软件具有更高的可靠性。,14,确定等价类的方式,在输入条件规定了取值范围或值的个数的情况下,则可以确立一个有效等价
10、类和两个无效等价类。在输入条件规定了输入值的集合或者规定了“必须如何”的条件的情况下,可以确立一个有效等价类和一个无效等价类。在输入条件是一个布尔量的情况下,可确定一个有效等价类和一个无效等价类。在规定了输入数据的一组值(假定n个),并且程序要对每一个输入值分别处理的情况下,可确立n个有效等价类和一个无效等价类。在规定了输入数据必须遵守的规则的情况下,可确立一个有效等价类(符合规则)和若干个无效等价类(从不同角度违反规则)。,15,根据等价类创建测试用例的步骤,建立等价类表,列出所有划分出的等价类:,为每个等价类规定一个唯一的编号;设计一个新的测试用例,使其尽可能多地覆盖尚未覆盖的有效等价类。
11、重复这一步,最后使得所有有效等价类均被测试用例所覆盖;设计一个新的测试用例,使其只覆盖一个无效等价类。重复这一步使所有无效等价类均被覆盖。,16,边界值测试用例设计方法,边界值分析法:程序的很多错误发生在输入或输出范围的边界上,因此针对各种边界情况设置测试用例,可以发现不少程序缺陷。设计方法:确定边界情况(输入或输出等价类的边界)选取正好等于、刚刚大于或刚刚小于边界值作为测试数据,17,确定边界值的方式,如果输入条件规定了值的范围,则应取刚达到这个范围的边界的值,以及刚刚超越这个范围边界的值作为测试输入数据。如果输入条件规定了值的个数,则用最大个数、最小个数、比最小个数少一、比最大个数多一的数
12、作为测试数据。如果程序的规格说明给出的输入域或输出域是有序集合,则应选取集合的第一个元素和最后一个元素作为测试用例。如果程序中使用了一个内部数据结构,则应当选择这个内部数据结构的边界上的值作为测试用例。分析规格说明,找出其他可能的边界条件。,18,错误推测法测试用例设计,基于经验和直觉推测程序中所有可能存在的各种错误,从而有针对性地设计测试用例。发现程序经常出现的错误的方法:单元测试中发现的模块错误;产品的以前版本曾经发现的错误;输入数据为0或字符为空;当软件要求输入时(比如在文本框中),不是没有输入正确的信息,而是根本没有输入任何内容,单单按了Enter键;这种情况在产品说明书中常常忽视,程
13、序员也可能经常遗忘,但是在实际使用中却时有发生。程序员总会习惯性的认为用户要么输入信息,不管是看起来合法的或非法的信息,要不就会选择Cancel键放弃输入,,19,测试场景法设计测试用例,现在的软件几乎都是用事件触发来控制流程的,事件触发时的情景便形成了场景,而同一事件不同的触发顺序和处理结果就形成事件流。这种在软件设计方面的思想也可引入到软件测试中,可以比较生动地描绘出事件触发时的情景,有利于测试设计者设计测试用例,同时使测试用例更容易理解和执行。,20,因果图法测试用例设计,多种输入条件的组合,产生多种结果设计测试用例。设计方法:分析软件规格说明文档描述的哪些是原因(输入条件),哪些是结果
14、(输出条件),给每个原因和结果赋予一个标示符。找出原因与结果,原因与原因之间的对应关系,划出因果图在因果图上标上哪些不可能发生的因果关系,表明约束或限制条件根据因果图,创建判定表,将复杂的逻辑关系和多种条件组合很具体明确的表示出来把判定表的每一行作为依据设计测试用例。,21,测试类型与测试用例设计,根据测试类型设计,根据程序功能模块设计,功能测试,易用性测试,配置测试,压力测试,回归测试,界面测试,文档测试,国际化测试,测试用例1 测试用例2 测试用例3,测试用例1 测试用例2 测试用例3,安装/卸载测试,联机帮助测试,软件更新测试,联机注册测试,文件操作测试,测试用例1 测试用例2 测试用例
15、3,测试用例1 测试用例2 测试用例3,数据备份测试,22,设计测试用例的策略选择,测试用例的设计方法不是单独存在的,具体到每个测试项目里都会用到多种方法,每种类型的软件有各自的特点,每种测试用例设计的方法也有各自的特点,针对不同软件如何利用这些黑盒方法是非常重要的。在实际测试中,往往是综合使用各种方法才能有效提高测试效率和测试覆盖度,这就需要认真掌握这些方法的原理,积累更多的测试经验,以有效提高测试水平。首先进行等价类划分,包括输入条件和输出条件的等价划分,将无限测试变成有限测试,这是减少工作量和提高测试效率的最有效方法。在任何情况下都必须使用边界值分析方法。经验表明用这种方法设计出测试用例
16、发现程序错误的能力最强。对照程序逻辑,检查已设计出的测试用例的逻辑覆盖程度。如果没有达到要求的覆盖标准,应当再补充足够的测试用例。对于业务流清晰的系统,可以利用场景法贯穿整个测试案例过程,在案例中综合使用各种测试方法。,23,测试用例设计工具,设计依据:软件需求文档软件设计文档,通用设计工具:Microsoft WordMicrosoft ExcelMicrosoft Access,设计工具专用:IBM Rational TestManagerMercury Interactive TestDirector,常见问题:软件文档不全或没有文档没有完成编码就开始设计测试用例,24,案例研究1:根据
17、输入判断三角形的形状,测试场景:一个程序读入3个整数,把这三个数值看作一个三角形的3条边的长度值。这个程序要打印出信息,说明这个三角形是不等边的、是等腰的、还是等边的。,确定输入数据与三角形形状的关系:设三角形的3条边分别为A,B,C。如果它们能够构成三角形的3条边,必须满足:A0,B0,C0,且A+BC,B+CA,A+CB;如果是等腰的,还要判断A=B,或B=C,或A=C;如果是等边的,则需判断是否A=B,且B=C,且A=C。,25,案例研究1:判断三角形的形状(续1),创建等价类表:,26,案例研究1:判断三角形的形状(续2),确定等价类输入数据:,27,案例研究2:测试用户登录对话框的功
18、能,测试场景:在各种输入条件下,测试程序的登录对话框功能。用户名和密码的规则如下:用户名长度为6至10位(含6位和10位)用户名由字符(a-z、A-Z)和数字(0-9)组成 不能为空、空格和特殊字符 密码规则同用户名规则,28,案例研究2:登录对话框的功能(续1),确定输入数据的情形:,29,案例研究2:登录对话框的功能(续2),确定具体的输入数据:,30,案例研究3:压力/负载测试用例设计,设计目的:验证程序在承受某种负载或压力下是否能够正常运行 找出程序安全运行的临界值适用情形:服务器/客户机局域网 服务器/浏览器互联网设计方法:设计出不同等级的压力条件,压力/负载分类与代号:CPU速度C
19、SCPU使用量CU磁盘空间DS物理内存PM虚拟内存使用量VM登录用户的数量UN传输带宽BW传输数据的大小DN,31,案例研究3:压力/负载测试用例设计(续1),32,案例研究4:测试软件对话框的界面设计,Deployment Testcase Test Case ID:62Title:UserExitFormPath:DeploymentGeneralAuthor:xxxxxPurpose:make sure the dialog to test is properly designed,look for truncations,wrong tab orders,duplicated hotk
20、eys,overlappings and any other posible issues Steps:Pre-steps:1.Launch App.2.Go to“Tools”/“Import/Export Settings”3.Select“General development settings”4.Click Reset Settings5.If you are prompted to save your settings,click“Dont save”6.A dialog appears telling you that the operation had been success
21、ful,33,案例研究5:测试中断安装软件的功能,Purpose:Verify the app can be canceled during installationTest Steps:1.Launch App Name2.From the drop down menu select File,New and Project3.The New project Dialog box should appear4.In“Project Types”,select“Other Project Types”and under this,“Setup and deployment”.From the“
22、Templates”select a setup project,give the project a name for example Deploy1 and press“OK”5.From the“Build”menu click“Build Solution”and wait until the project has been built6.Close the project and navigate to the folder where you saved your project7.Double click the Setup folder and then double cli
23、ck the Debug folder8.Click the Setup.exe to launch the Windows Installer9.At the first stage of the wizard click the“Cancel”button and click“Yes”when asked are you sure you want to exit10.The Installation Interrupted dialog appears,34,案例研究6:测试软件中文大字符集的支持,Create and structure a site with GB 18030 cha
24、racterApp name is a very complex product,and its ability of site management as well as multimedia authoring is quite powerful.The following testcases is used to test the performance in supporting GB 18030 when creating a site.Title:Create a Blank Site with GB 18030 CharacterSteps:Launch App name.Cho
25、ose File New Site to open the site wizard.Select Single User and click Next.Select Blank Site to create a project folder and Click Next.In Site Name field on the dialog,type in or copy/paste GB 18030 characters as site name.Click Next.Choose location where you want to store all folders of this new site.Verify this new site is created,with correct project folder name as desired.In File panel,verify this site name with GB18030 character can display properly as desired.,
链接地址:https://www.31ppt.com/p-6126534.html