软件测试模型软件测试设计.doc

上传人:豆**** 文档编号:17679422 上传时间:2022-05-25 格式:DOC 页数:12 大小:162KB
返回 下载 相关 举报
软件测试模型软件测试设计.doc_第1页
第1页 / 共12页
软件测试模型软件测试设计.doc_第2页
第2页 / 共12页
点击查看更多>>
资源描述

《软件测试模型软件测试设计.doc》由会员分享,可在线阅读,更多相关《软件测试模型软件测试设计.doc(12页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、【精品文档】如有侵权,请联系网站删除,仅供学习与交流软件测试模型软件测试设计.精品文档.软件测试模型测试策略的简介测试策略包括:单元测试、设计测试用例、要测试哪几方面的问题,针对这几方面问题各自测试什么内容,测试的具体步骤及实用测试策略瀑布模型、螺旋模型、圆形开发模型、增量开发模型、渐进模型、快速应用开发模型测试分为单元测试、集成测试、系统测试和确认(验收)测试单元测试 针对程序中的模块或构件 主要揭露编码阶段产生的错误单元测试又称模块测试、逻辑测试或结构测试单元测试的目的:发现各模块内部可能存在的各种差错测试的方法:一般采用白盒法,以路径覆盖为最佳准则,且系统内多模块可以并行地进行测试集成测

2、试 针对集成的软件系统 主要揭露设计阶段产生的错误集成测试也称组装测试,综合测试或联合测试集成测试:是按设计要求把通过单元测试的各个模块组装在一起之后进行测试,以便发现与接口有关的各种错误。集成测试需要考虑的有关问题(即为什么要进行集成测试) 数据经过接口是否会丢失;一个模块对另一个模块是否造成不应有的影响;几个子功能组合起来三能否实现主功能;误差不断积累是否达到不可接受的程度;全局数据结构是否有问题系统测试: 主要揭露不符合系统工程中对软件要求的错误 在系统测试实施之前软件工程是应完成以下工作 为测试软件系统的输入信息设计出错处理通路设计测试用例模拟错误数据和软件界面可能发生的错误记录确认测

3、试 检查软件能否按合同要求进行工作,即是否满足软件需求说明书中的确认标准 验收测试又称有效性测试合格测试或确认测试 模块组装后已成为完整的软件包,消除了接口的错误确认测试主要由使用用户参加测试,检验软件规格说明的技术标准的符合程度,是保证软件质量的最后关键环节V模型 即快速应用开发模型 需求分析验收测试系统规格系统测试概要设计集成测试详细设计单元测试编码 应尽早测试才能尽快发现错误降低日后维护中的消耗 所以说需求设计也是需要测试的V模型的优点 明确表明了测试过程中存在的不同级别清楚的描述了测试阶段与开发过程各阶段的对应关系V模型的测试策略包括了低层测试(代码)又包括了高层测试(需求)V模型的缺

4、点他仅仅把测试过程作为需求分析概要设计详细设计编码之后的一个阶段容易让人理解为测试是软件开发的最后一个阶段没有明确说明早期的测试,不符合越早测试和不断地测试的原则与实际的测试活动也不符W模型 用户需求双V验收测试设计 交付 验收测试 需求分析双V 系统测试设计 实施系统测试 概要设计双V 集成测试设计 集成 集成测试 详细设计双V 单元测试设计 单元测试 编码 此模型强调:测试伴随着整个软件开发周期,测试的对象不仅仅是程序,需求、功能和设计同样需要测试。测试与开发是同步进行的优点: 符合尽早测试和不断测试的原则符合实际工作中的测试原则符合实际工作中的测试活动缺点: 视软件开发活动是一系列串行的

5、活动开发和测试保持一种现行的前后关系 这样就无法支持迭代H模型 所以相应的测试之间也不存在准备测试 测试执行 测试就绪点其他流程(如设计流程、开发流程)说明软件测试不仅仅指测试的执行还包括很多其他的活动软件测试是一个独立的流程,贯穿产品整个生命周期,与其他流程并发进行只要测试条件策划能够成熟了,测试准备活动完成了,测试执行活动就可以进行了。X模型 程序片断1 固定版本 测试设计 执行测试 工具配置 测试设计 执行测试 工具配置编码完成 集成1n执行测试 探索性测试测试设计 程序片断n执行测试左边描述的是针对单独程序片断进行的相互分离的编码和测试以后将频繁交换 最终集成为产品进行版本固定交付用户

6、使用软件测试设计设计测试用例即时贴程序程序功能便签的数量最多为50个标题字数最多40字节便签正文字数最多200个年份只能设置在1900-2100之间测试用例 为实施测试面向被测试系统提供的输入数据、操作或各种环境设置以及期望结果的一个特定集合 解决要测什么,怎么测和如何衡量的问题测试用例的目的:执行测试,发现缺陷重复执行测试,重现缺陷管理测试过程回归测试、验证缺陷是否修复优点:使测试更加方便的执行;提高测试效率;节省测试时间;使测试更能按时间计划进行;使测试过程更方便管理准备工作收集资料需求文档设计文档遗留系统的相关文档与相关人员讨论探索性测试 探索性测试与经过深思熟虑的、计划好的的测试过程有

7、所不同,它依靠的是测试人员的知识水平和创造力。 可用于重现和分析缺陷、研究缺陷和程序其他模块的相关性 是测试用例有利的补充 具体问题具体分析测试用例的内容 项目名称(版本)模块名称测试功能项 项目人员测试时间 测试目的预置条件其他参考信息 测试用例编号相关用例 用例说明输入条件执行方法 预期结果测试结果缺陷编号常用的测试用例设计方法 黑盒测试&白盒测试黑盒测试 是对需求的所有输入条件进行测试定义:被称为功能测试或数据驱动测试,在测试时,把被测试程序视为一个黑盒,在不考虑程序内部结构和内部特性的情况下进行测试黑盒测试方法等价类划分 分类 每类中选取几个数值 等价类划分步骤:划分等价类:不考虑程序

8、的内部结构测试人员要对需求规格说明书的功能需求进行细致分析然后把程序的输入域划分成若干部分 从每个部分中选取少数代表性数据当作测试用例,经过这种划分后,每一类的代表性数据在测试中的作用都等价于这一类的其他值。建立等价类表确定等价类细化等价类划分等价类划分 分为有效等价类和无效等价类 合理的有意义的输入数据构成的集合就是有效等价类 不合理的、无意义的输入数据构成的集合。用来检查程序中功能的实现是否不符合规格说明要求。就是无效等价类。等价类测试的重要意义 提供了完备性;保证了无冗余性目的 为了减少测试用例等价类划分规则为每个等价类规定一个唯一的编号 设计一个新的测试用例使其尽可能多的覆盖违背覆盖的

9、有效等价类 为了工作的高效,此项工作重复进行 知道所有的有效等价类都被覆盖为止。设计一个新的测试用例使其覆盖一个而且仅仅一个尚未被覆盖的无效等价类 避免出错 此项工作重复进行知道所有的无效等价类都被覆盖为止。之所以要这样做是因为某些程序中对某一输入错误俄检查往往会评比对其他输入错误的检查,因此必须针对每一个无效等价类分别设计测试用例等价类划分原则 如果输入条件规定了取值范围或者值的个数 则可以确定一个有效等价类和两个无效等价类 例如序号值为1到999 1个有效类 序号值为1 2个无效类 序号值999 如果输入条件规定了输入值得集合或者是规定了必须如何的条件这时可确立一个有效等价类和一个无效等价

10、类 例如 c语言对变量标识符规定为 以字母打头的串,所有字母打头的就是有效等价类 如果输入条件是一个布尔量,则可以确定一个有效等价类一个无效等价类 如果规定了输入数据时一组值,而且程序要对每个输入值分别进行处理 这时可为每一个输入值确立一个有效等价类,此外在针对这组确立一个无效等价类它应该是所有不允许输入值得结合 如果规定了输入数据必须遵守的规则则可以确定一个有效等价类(符合规则)。和若干个无效等价类(从不同角度违反规则)保险费率计算问题(实战) 某保险公司承担忍受保险,该公司保费计算方式为:保费=投保额*保险率,保险率依点数不同而有别,10点以上(含10点),费率为0.6%,10点以下费率为

11、0.1%点数的计算是年龄、性别、婚姻、扶养人数所得的点数的总和输入:年龄、性别、婚姻、扶养人数输出:保险率 年龄 20-39 6点40-59 4点99以下59以上 ,20以下1以上 2点性别 男 5点 女 3点婚姻 已婚 3点 未婚 5点扶养人数 1人扣0.5点 最多扣3点(四舍五入) 编写用例 设计测试用例,尽可能的覆盖尚未覆盖的有效等价类1,8,10.,122,9,11,133,8,10,14设计测试用例,使得每一个新设计的测试用例只包含一个无效等价类,其他的选择有效等价类4 8 10 125 9 11 136 8 10 147 8 10 141 8 10 152 9 11 163 8 1

12、0 16等价类的特点 测试内容相同 如果等价类中的一个测试能够捕获一个缺陷,那么选择该等价类中的其他测试也能捕获该缺陷 如果等价类中的一个测试不能够捕获一个缺陷,那么选择该等价类中的其他测试也不能捕获该缺陷注意 考虑无效等价类;仔细划分经典笔试题三角形问题 一个程序读入3个整数,把这三个数值看作一个三角形的3条边的长度值,这个程序要打印出信息,说明这个三角形是不等边的,是等腰的,还是等边的,利用等价类划分的方法,给出足够的测试用例。解题思路: 我们可以设三角形的3条边分别为A B C,如果他们能够构成三角形的3条边,必须满足: A0,B0,C0且A+BC, B+CA,A+CB 如果是等腰的,还

13、要判断A=B,或B=C,或A=C 如果是等边的,还要判断A=B且B=C,或A=C且 B=C 输入条件 有效等价类 无效等价类 A0 A+BCA=0A+B0 B+CAB=0B+C0 A+CB C=0A+C=B 是等腰A=B A不等于B 且 B=CB不等于C 且C=AC不等于A是等边 A=B=CA不等于BB不等于CC不等于A设计用例:3.4.51.2.3.4.5.6一般三角形0.1.271.0.281.2.091.2.3101.3.2113.1.2123.3.41.2.3.4.5.6.13等腰3.4.41.2.3.4.5.6.14等腰3.4.31.2.3.4.5.6.15等腰3.4.51.2.3.

14、4.5.6.16非等腰一般三角形3.3.31.2.3.4.5.6.17等边3.4.41.2.3.4.5.6.14.18非等边一般三角形3.4.31.2.3.4.5.6.15.19非等边一般三角形3.3.41.2.3.4.5.6.13.20非等边一般三角形边界值边界值方法小结 输入或输出的边界最容易产生错误 确定边界值的方法 对取值范围进行界定 对取值个数进行界定 有序集合 分析规格说明,找出其他边界条件隐含的边界值 2的乘方 ASCII表单缺陷假设边界值分析的关键假设;在可靠性理论中叫做单缺陷假设,失效极少是由两个或者多个缺陷同时发生引起的;基本边界值获得测试用例的方法,使所有的变量取正常值,

15、只有一个变量取极值。对于一个有n个变量的程序,保留其中一个变量,让其余的变量取正常值,被保留的变量取正常值,被保留的变量依次取min,min+,nom,max-,max值,对每个变量都重复进行。这样,对于一个有n个变量的程序,边界值分析测试程序会产生4n+1个测试用例找零钱的最佳组合(实战) 假设商店商品价格X皆不大于100元(整数),若顾客买一件商品,付款Y在100元内,求找给顾客的最少货币张数? 货币面值 502010521定义找回零钱为S S 输入 输出 找回张数 X Y 502010521 101 0100 101100 99 50 5010011 49511002125 208010

16、011 19811001124 109010011 991100123 59510011 49610022 29810011 19910011决策表(决策表)判定图方法小结:分析输入条件和输出条件分析,简化画出输入输出关系图(判定表)得出测试用例决策表法是黑盒测试方法中最为严格、最具有逻辑性的测试方法决策表的优点: 它能够将复杂的问题按照各种可能的情况全部列出,简明并避免遗漏,因此,利用决策表能够设计出完整的测试用例集合判定图内容:条件桩 列出问题的所有条件 条件项 针对条件桩给出的条件列出所有可能的取值 动作桩 列出问题规定的可能采取的操作 动作项 指出在条件项的各个组取值情况下应采取的动作

17、决策表化简(动作相同是前提)合并:如果一个条件相和另外一个条件相动作时相同的,且两个条件相对应的每一行的执只有一个是不同的,则可以将其合并,合并的项除了不同值变成不关心条目外其余不变包含:如果两个条件相的动作时相同的,对人以条件1的值和条件2种对应的值,如果满足:A如果条件1的值是T(F),则条件2种的值也是T(F) B如果条件1的值是不关心,则条件2中的值是T,F,不关心,称条件1包含条件2,条件2可以撤去 C重复A,B两条就可以得到精简的决策表决策表的步骤: 确定规则个数,假设有N个条件,则有2的N次幂个规则列出所有的条件桩和动作桩填入条件项填入动作项,制定初始决策表进行简化,合并相似规则

18、或者相同动作决策表的使用范围:规格说明以判定表的形式给出的,或者很容易转换成判定表条件的排列顺序和规则的排列顺序不影响执行哪些操作规则之间是独立的,某一规则触发的操作与其他规则无关组合测试方法 组合测试关注的是用例对输入变量取值的组合覆盖情况 常见的组合策略有:全组合,单因素覆盖,两两组合覆盖全组合覆盖:是指所有测试用例覆盖所有的输入变量取值间的组合,全组合的数目为变量取值数目间的组合。全组合覆盖测试能够发现软件中所有的缺陷,但是我们是无法对软件进行全组合覆盖测试单因素组合覆盖:所选的测试用例覆盖所有的变量取值,单因素组合覆盖所需的用例数与取值最多的变量的取值数相同。单因素组合覆盖能够发现软件

19、中所有的单点故障两两组合(成对组合)覆盖:所选的测试用例覆盖所有的任意两个输入变量间取值的组合情况。可以用成对组合集合来表示通常的测试用例集,对于某个给定的测试用例,它能覆盖一定数量的成对组合元素,例如:测试用例A1B1C2覆盖了(A1,B1),(A1,C2),(B1,C2)3个成对组合元素。航空公司托运费计算(实战)某航空公司行李托运费处理规则,低于30公斤(含)免运费,超过30公斤,头等舱的国内乘客,超重1公斤4元,其他舱的国内乘客,超重1公斤6元,国外乘客加一倍,残疾乘客减一倍判定树决策表123456789国内-TTTTFFFF头等-TFTFTFTF残疾-FFTTFFTT小于30TFFF

20、FFFFF免费X2X3X4XX6XX8X12X猜错法错误猜测:错误猜测是基于经验和直觉推测程序中所有可能存在的各种错误,从而针对性地设计测试用例的方法需要测试人员具备的技术: 有关被测系统的知识,如设计方法或实现技术 有关的早期测试阶段的结果的知识 测试类似或相关系统的经验 典型的实现错误的知识通用的测试经验规则随机测试的缺点 无法度量随机测试实际覆盖率 许多测试都是冗余的 确定预期结果可能会花费大量的时间 测试数据因为是随机的,重复测试是不可能的如何选择测试方法:任何情况下都必须使用边界值分析方法用等价类划分方法补充一些测试用例用错误推测法在追加一些测试用例如果程序的功能说明中含有输入条件的

21、组合情况,则应在一开始就选用因果图法 如果程序某功能适合自动测试,可以采用自动测试以及随机测试软件故障模型 概念:测试时有太多的单个输入变量、多个输入变量的组合,我们把这些测试人员的经验和直觉尽量归纳和固化,形成一些故障模型 输入非法数据 输入类型 输入字符长度 边界值 输入默认值 无效输出 数据结构溢出如何评价测试设计的好坏 是否可以发现尚未发现的软件缺陷是否可以覆盖全部的测试需求 易用性:应当可以花费很少的时间就可以理解测试用例中表达的测试思路并可以很快地执行完这个测试用例 易维护性:花费很少的时间就完成定位并维护所有相关测试用的工作 有效验证用户需求:在产品之后的运行中可以充分满足用户需

22、求,不发生重大漏测问题城区电话号码(实战) 某城市电话号码由三部分组成,分别是 地区码空白或三位数字 前缀非0或1开头的三位数字 后缀4位数字 假定被测程序能够接受一切符合上述规定的电话号码,拒绝所有不符合规定的电话号码,要求1请选择适当的黑盒测试方法,写出选择该方法的原因,并使用该方法的步骤,给出测试用例表2如果所生成的测试用例不够全面,请考虑用别的测试方法生成一些补充的测试用例 选择等价类划分有效无效地区码 空白1 三位数字2 任意字符 3 小于3位数 4 大于3位数 5前缀200999 6 任意字符 7小于3位数 8 大于3位数 9 起始为0 10 起始为1 11后缀4位数字12 小于4位 13 大于4位 14 任意字符 15

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

当前位置:首页 > 教育专区 > 小学资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁