ImageVerifierCode 换一换
格式:DOCX , 页数:9 ,大小:24.91KB ,
资源ID:6209307      下载积分:12 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6209307.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(测试用例编写技巧.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

测试用例编写技巧.docx

1、测试用例编写技巧测试用例 (Test Case是为某个特殊目标而编制的一组测试输入、执行条件以及预期结果, 以便测试某个程序路径或核实是否满足某个特定需求。测试用例目前没有经典的定义。 比较通常的说法是:指对一项特定的软件产品进行测试 任务的描述, 体现测试方案、 方法、 技术和策略。 内容包括测试目标、 测试环境、 输入数据、 测试步骤、预期结果、测试脚本等,并形成文档。不同类别的软件,测试用例是不同的。不同于诸如系统、工具、控制、游戏软件,管理 软件的用户需求更加不统一,变化更大、 更快。 笔者主要从事企业管理软件的测试。 因此我 们的做法是把测试数据和测试脚本从测试用例中划分出来。 测试

2、用例更趋于是针对软件产品 的功能、 业务规则和业务处理所设计的测试方案。 对软件的每个特定功能或运行操作路径的 测试构成了一个个测试用例。随着中国软件业的日益壮大和逐步走向成熟, 软件测试也在不断发展。 从最初的由软件 编程人员兼职测试到软件公司组建独立专职测试部门。测试工作也从简单测试演变为包括:编制测试计划、编写测试用例、准备测试数据、编写测试脚本、实施测试、测试评估等多项 内容的正规测试。 测试方式则由单纯手工测试发展为手工、 自动兼之, 并有向第三方专业测 试公司发展的趋势。要使最终用户对软件感到满意 , 最有力的举措就是对最终用户的期望加以明确阐述,以 便对这些期望进行核实并确认其有

3、效性。 测试用例反映了要核实的需求。 然而, 核实这些需 求可能通过不同的方式并由不同的测试员来实施。 例如, 执行软件以便验证它的功能和性能, 这项操作可能由某个测试员采用自动测试技术来实现 ; 计算机系统的关机步骤可通过手工测 试和观察来完成 ; 不过, 市场占有率和销售数据 (以及产品需求 , 只能通过评测产品和竞争销 售数据来完成。既然可能无法 (或不必负责 核实所有的需求,那么是否能为测试挑选最适合或最关键的 需求则关系到项目的成败。 选中要核实的需求将是对成本、 风险和对该需求进行核实的必要 性这三者权衡考虑的结果。确定测试用例之所以很重要,原因有以下几方面。测试用例构成成了设计和

4、制定测试过程的基础。测试的 “深度” 与测试用例的数量成比例。由于每个测试用例反映不同的场景、条件或 经由产品的事件流, 因而, 随着测试用例数量的增加, 您对产品质量和测试流程也就越有信 心。判断测试是否完全的一个主要评测方法是基于需求的覆盖,而这又是以确定、实施和 /或执行的测试用例的数量为依据的。类似下面这样的说明:“ 95 % 的关键测试用例已得以 执行和验证” ,远比“我们已完成 95 % 的测试”更有意义。测试工作量与测试用例的数量成比例。 根据全面且细化的测试用例, 可以更准确地估计 测试周期各连续阶段的时间安排。测试设计和开发的类型以及所需的资源主要都受控于测试用例。通常测试用

5、例通常根据它们所关联关系的测试类型或测试需求来分类, 而且将随类型和 需求进行相应地改变。最佳方案是为每个测试需求至少编制两个测试用例:一个测试用例用于证明该需求已经满足,通常称作正面测试用例 ;另一个测试用例反映某个无法接受、 反常或意外的条件或数据, 用于论证只有在所需 条件下才能够满足该需求,这个测试用例称作负面测试用例。一、测试用例是软件测试的核心软件测试的重要性是毋庸置疑的。 但如何以最少的人力、 资源投入, 在最短的时间内完 成测试,发现软件系统的缺陷, 保证软件的优良品质,则是软件公司探索和追求的目标。每 个软件产品或软件开发项目都需要有一套优秀的测试方案和测试方法。影响软件测试

6、的因素很多,例如软件本身的复杂程度、开发人员 (包括分析、设计、编 程和测试的人员 的素质、测试方法和技术的运用等等。因为有些因素是客观存在的,无法 避免。有些因素则是波动的、不稳定的,例如开发队伍是流动的,有经验的走了,新人不断 补充进来 ; 一个具体的人工作也受情绪等影响,等等。如何保障软件测试质量的稳定 ? 有了测 试用例,无论是谁来测试,参照测试用例实施,都能保障测试的质量。 可以把人为因素的影 响减少到最小。 即便最初的测试用例考虑不周全, 随着测试的进行和软件版本更新, 也将日 趋完善。因此测试用例的设计和编制是软件测试活动中最重要的。测试用例是测试工作的指导, 是软件测试的必须遵

7、守的准则。更是软件测试质量稳定的根本保障。二、编制测试用例着重介绍一些编制测试用例的具体做法。1、测试用例文档编写测试用例文档应有文档模板, 须符合内部的规范要求。 测试用例文档将受制于测试 用例管理软件的约束。软件产品或软件开发项目的测试用例一般以该产品的软件模块或子系统为单位, 形成一 个测试用例文档,但并不是绝对的。测试用例文档由简介和测试用例两部分组成。 简介部分编制了测试目的、 测试范围、 定 义术语、参考文档、 概述等。测试用例部分逐一列示各测试用例。 每个具体测试用例都将包 括下列详细信息:用例编号、用例名称、测试等级、入口准则、验证步骤、期望结果 (含判 断标准 、出口准则、注

8、释等。以上内容涵盖了测试用例的基本元素:测试索引,测试环境, 测试输入,测试操作,预期结果,评价标准。2、测试用例的设置我们早期的测试用例是按功能设置用例。 后来引进了路径分析法, 按路径设置用例。 目 前演变为按功能、路径混合模式设置用例。按功能测试是最简捷的,按用例规约遍历测试每一功能。对于复杂操作的程序模块, 其各功能的实施是相互影响、 紧密相关、环环相扣的, 可以 演变出数量繁多的变化。 没有严密的逻辑分析, 产生遗漏是在所难免。 路径分析是一个很好 的方法,其最大的优点是在于可以避免漏测试。但路径分析法也有局限性。 在一个非常简单字典维护模块就存在十余条路径。 一个复杂 的模块会有几

9、十到上百条路径是不足为奇的。笔者以为这是路径分析比较合适的使用规模。 若一个子系统有十余个或更多的模块, 这些模块相互有关联。 再采用路径分析法, 其路径数 量成几何级增长, 达 5位数或更多, 就无法使用了。 那么子系统模块间的测试路径或测试用 例还是要靠传统方法来解决。这是按功能、路径混合模式设置用例的由来。3、设计测试用例测试用例可以分为基本事件、 备选事件和异常事件。 设计基本事件的用例, 应该参照用例规约 (或设计规格说明书 ,根据关联的功能、操作按路径分析法设计测试用例。而对孤立 的功能则直接按功能设计测试用例。基本事件的测试用例应包含所有需要实现的需求功能, 覆盖率达 100%。

10、设计备选事件和异常事件的用例,则要复杂和困难得多。例如,字典的代码是唯一的, 不允许重复。 测试需要验证:字典新增程序中已存在有关字典代码的约束, 若出现代码重复 必须报错, 并且报错文字正确。 往往在设计编码阶段形成的文档对备选事件和异常事件分析 描述不够详尽。而测试本身则要求验证全部非基本事件,并同时尽量发现其中的软件缺陷。可以采用软件测试常用的基本方法:等价类划分法、 边界值分析法、错误推测法、 因果 图法、 逻辑覆盖法等设计测试用例。 视软件的不同性质采用不同的方法。 如何灵活运用各种 基本方法来设计完整的测试用例, 并最终实现暴露隐藏的缺陷, 全凭测试设计人员的丰富经 验和精心设计。

11、三、测试用例在软件测试中的作用1、指导测试的实施测试用例主要适用于集成测试、 系统测试和回归测试。 在实施测试时测试用例作为测试 的标准, 测试人员一定要按照测试用例严格按用例项目和测试步骤逐一实施测试。 并对测试 情况记录在测试用例管理软件中,以便自动生成测试结果文档。根据测试用例的测试等级, 集成测试应测试那些用例, 系统测试和回归测试又该测试那 些用例,在设计测试用例时都已作明确规定,实施测试时测试人员不能随意作变动。2、规划测试数据的准备在我们的实践中测试数据是与测试用例分离的。 按照测试用例配套准备一组或若干组测 试原始数据, 以及标准测试结果。 尤其象测试报表之类数据集的正确性,

12、按照测试用例规划 准备测试数据是十分必须的。除正常数据之外,还必须根据测试用例设计大量边缘数据和错误数据。3、编写测试脚本的 设计规格说明书 为提高测试效率, 软件测试已大力发展自动测试。 自动测试的中心任务是编写测试脚本。如果说软件工程中软件编程必须有设计规格说明书, 那么测试脚本的设计规格说明书就是测 试用例。4、评估测试结果的度量基准完成测试实施后需要对测试结果进行评估, 并且编制测试报告。 判断软件测试是否完成、 衡量测试质量需要一些量化的结果。 例:测试覆盖率是多少、 测试合格率是多少、 重要测试 合格率是多少, 等等。以前统计基准是软件模块或功能点,显得过于粗糙。 采用测试用例作

13、度量基准更加准确、有效。5、分析缺陷的标准通过收集缺陷, 对比测试用例和缺陷数据库, 分析确证是漏测还是缺陷复现。 漏测反映 了测试用例的不完善, 应立即补充相应测试用例, 最终达到逐步完善软件质量。 而已有相应 测试用例,则反映实施测试或变更处理存在问题。四、相关问题1、测试用例的评审测试用例是软件测试的准则, 但它并不是一经编制完成就成为准则。 测试用例在设计编 制过程中要组织同级互查。 完成编制后应组织专家评审, 需获得通过才可以使用。 评审委员 会可由项目负责人、测试、编程、分析设计等有关人员组成,也可邀请客户代表参加。2、测试用例的修改更新测试用例在形成文档后也还需要不断完善。 主要

14、来自三方面的缘故:第一、 在测试过程 中发现设计测试用例时考虑不周,需要完善 ; 第二、在软件交付使用后反馈的软件缺陷,而 缺陷又是因测试用例存在漏洞造成 ; 第三、软件自身的新增功能以及软件版本的更新,测试 用例也必须配套修改更新。一般小的修改完善可在原测试用例文档上修改, 但文档要有更改记录。 软件的版本升级 更新,测试用例一般也应随之编制升级更新版本。3、测试用例的管理软件运用测试用例还需配备测试用例管理软件。 它的主要功能有三个:第一、 能将测试用例 文档的关键内容, 如编号、 名称等等自动导入管理数据库, 形成与测试用例文档完全对应的 记录 ; 第二、可供测试实施时及时输入测试情况

15、; 第三、最终实现自动生成测试结果文档,包含各测试度量值,测试覆盖表和测试通过或不通过的测试用例清单列表。有了管理软件, 测试人员无论是编写每日的测试工作日志、 还是出软件测试报告, 都会 变得轻而易举。五、测试用例的设计(一 白盒技术白合测试是结构测试结构测试, 所以被测对象基本上是源程序, 以程序的内部逻辑为基 础设计测试用例。1、逻辑覆盖程序内部的逻辑覆盖程度, 当程序中有循环时, 覆盖每条路径是不可能的, 要设计使覆 盖程度较高的或覆盖最有代表性的路径的测试用例。 下面根据图 7-1所示的程序, 分别讨论 几种常用的覆盖技术。(1语句覆盖。为了个提高发现错误的可能性, 在测试时应该执行

16、到程序中的每一个语句。 语句覆盖是 指设计足够的测试用例,使被测试程序中每个语句至少执行一次。如图 7-1是一个被测试程序流程图:(2判定覆盖。判定覆盖指设计足够的测试用例,使得被测程序中每个判定表达式至少获得一次“真” 值和“假”值,从而使程序的每一个分支至少都通过一次,因此判定覆盖也称分支覆盖。(3条件覆盖。条件覆盖是指设计足够的测试用例, 使得判定表达式中每个条件的各种可能的值至少出 现一次。(4判定 /条件测试。该覆盖标准指设计足够的测试用例, 使得判定表达式的每个条件的所有可能取值至少出 现一次,并使每个判定表达式所有可能的结果也至少出现一次。(5条件组合覆盖。条件组合覆盖是比较强的

17、覆盖标准, 它是指设计足够的测试用例, 使得每个判定表达式 中条件的各种可能的值的组合都至少出现一次。(6路径覆盖。路径覆盖是指设计足够的测试用例,覆盖被测程序中所有可能的路径。在实际的逻辑覆盖测试中, 一般以条件组合覆盖为主设计测试用例, 然后再补充部分用 例,以达到路径覆盖测试标准。2. 循环覆盖3. 基本路径测试(二 黑盒技术1. 等价类划分(1划分等价类。如果某个输入条件规定了取值范围或值的个数。则可确定一个合理的等价类 (输入值 或数在此范围内 和两个不合理等价类 (输入值或个数小于这个范围的最小值或大于这个范 围的最大值 。如果规定了输入数据的一组值, 而且程序对不同的输入值做不同

18、的处理, 则每个允许 输入值是一个合理等价类,此处还有一个不合理等价类 (任何一个不允许的输入值 。如果规定了输入数据必须遵循的规则, 可确定一个合理等价类 (符合规则 和若干个不 合理等价类 (从各种不同角度违反规则 。如果已划分的等价类中各元素在程序中的处理方式不同, 则应将此等价类进一步划分 为更小的等价类。(2确定测试用例。为每一个等价类编号。设计一个测试用例, 使其尽可能多地覆盖尚未被覆盖过的合理等价类。 重复这步, 直 到所有合理等价类被测试用例覆盖。设计一个测试用例,使其只覆盖一个不合理等价类。2. 边界值分析使用边界值分析方法设计测试用例时一般与等价类划分结合起来。 但它不是从

19、一个等价 类中任选一个例子作为代表, 而是将测试边界情况作为重点目标, 选取正好等于、 刚刚大于 或刚刚小于边界值的测试数据。(1如果输入条件规定了值的范围,可以选择正好等于边界值的数据作为合理的测试用 例,同时还要选择刚好越过边界值的数据作为不合理的测试用例。如输入值的范围是 1, 100,可取 0, 1, 100, 101等值作为测试数据。(2如果输入条件指出了输入数据的个数,则按最大个数、最小个数、比最小个数少 1、 比最大个数多 1等情况分别设计测试用例。如,一个输入文件可包括 1-255个记录,则分 别设计有 1个记录、 255个记录,以及 0个记录的输入文件的测试用例。(3对每个输

20、出条件分别按照以上原则 (1或 (2确定输出值的边界情况。如,一个学生成 绩管理系统规定,只能查询 95-98级大学生的各科成绩,可以设计测试用例,使得查询范 围内的某一届或四届学生的学生成绩,还需设计查询 94级、 99级学生成绩的测试用例 (不 合理输出等价类 。由于输出值的边界不与输入值的边界相对应, 所以要检查输出值的边界不一定可能, 要 产生超出输出值之外的结果也不一定能做到,但必要时还需试一试。(4如果程序的规格说明给出的输入或输出域是个有序集合 (如顺序文件、线形表、链表 等 ,则应选取集合的第一个元素和最后一个元素作为测试用例。3. 错误推测在测试程序时, 人们可能根据经验或直

21、觉推测程序中可能存在的各种错误, 从而有针对 性地编写检查这些错误的测试用例,这就是错误推测法。4. 因果图等价类划分和边界值方法分析方法都只是孤立地考虑各个输入数据的测试功能, 而没有 考虑多个输入数据的组合引起的错误。5. 综合策略每种方法都能设计出一组有用例子, 用这组例子容易发现某种类型的错误, 但可能不易 发现另一类型的错误。因此在实际测试中,联合使用各种测试方法,形成综合策略,通常先 用黑盒法设计基本的测试用例,再用白盒法补充一些必要的测试用例。入行软件测试行业 2年, 从事过自动化的测试和手工的功能测试。 两年来一直没有总结过自 己的工作。每当一听人问起一个简单的问题,如何编写好

22、的测试用例 ?如此简单的问题一问,仔细一想,思绪凌乱无章。这就是没有好好思考过的原因。 今天在博客总结下自己的看法,如何编写测试用例:1、了解软件的原始需求 (测试目的 在编写一个软件或者模块的测试用例时候, 一定要明白这个功能的原始需求, 也就是软 件的使用者 (客户 的需求。理解原始需求后,编写的测试用例才更有目的性。2、熟悉软件的功能需求 (测试点 这个功能需求是指软件的细化需求点, 这个一般在需求文档里面都会体现。 这里要做的 是把需求稳定的“粗略”的需求,细化成一个个小需求点。熟悉功能需求后,要知道软件是怎么使用的,这也才能覆盖到各种操作。总之,测试用例一定要全部覆盖所以的需求点,这

23、是最基本的一点。3、熟悉软件的实现原理 (测试点 在理解原始需求和软件的功能需求后,软件有什么功能,如何使用就基本上都知道啦。 这时候在根据需求编写测试用例,基本上都能覆盖的比较全面。在此基础上,熟悉软件的实现原理,理解软件的内部处理。(1熟悉原理的过程是进一步深入熟悉软件的过程。如果单单是从需求点上面覆盖案例, 测试用例只能覆盖“表面”的一层。一些内部的处理流程也许没有覆盖到,而这些没有覆盖到的代码很可能就是一个风险点。(2熟悉模块原理后,还有一点就是易于分析软件模块的关联性。一个大型的软件,都 是一些小模块的组合而成。软件越是大型,耦合就越大。 “互相影响”就会越多,设计用例单单是从模块本

24、身考虑的话,很可能就会对其他模块造成风险。4、用户场景和网上问题 (测试点 从用户的使用场景考虑, 这些在一些网络设备比较重要。 比如软件后期在一些真实的使 用环境中使用。还要就是从一些网上问题总结出来的, 那些地方容易出错。 在设计案例的时候需要考虑 进去5、测试用例的框架我觉得一个测试用例的框架体现了一个测试人员在设计测试用例的整体思路。 框架也是 从大到小划分下来,可以是:UI 界面,功能,容错,兼容,性能等几大类,每个大类在根据软件的逻辑等进行划分 成小类,最后细分到测试点。 6、测试步骤(测试技巧方法 前面 4 点都是从测试点的角度考虑, 测试用例在完成测试点外, 下来就是测试步骤和

25、测 试结果啦。 测试用例可以写的很详细,也可以写的比较简单。看公司的要求,有些公司要去测试步 骤很细很细,包括测试结果和测试步骤一一对应。 我个人不太认同这种做法, 测试用例最重要的我认为是测试点。 只要理解了测试目的后, 下来的就是测试人员的执行工作啦。如果对一些非常娴熟的测试人员,他们一般 看测试用例的标题就是知道你测试目的了, 具体的操作就是根据他们的测试方法进行测 试。如果测试步骤写的很详细的话,一会很耗时间。你要考虑到文字语音的描述,以及一些 前置步骤的操作, 这也会导致案例有时候像个文章, 而且过于详细的会限制执行人员的思维。 要求测试步骤写的很详细的公司, 一般是怕执行人员的执行

26、力不到位, 导致没有理解案 例的目的,导致漏测。一般出现在新员工对软件系统的不熟悉。 7、测试用例的一些思路 在设计案例中,我用的最多的是边界值,等价类,正常和异常的测试。下面是我想到的 几个方面:(结合一些网上文章的观点 一从单个模块或者单个功能点考虑 (1UI 界面(易用性,提示信息,整体布局,色彩,中英文标点错别字 (2数据的多样性 有效数据 合法的无效数据(边界值 非法和异常数据 各种数据的组合 (3操作多样性 添加删除编辑查询 多用户的操作 (4容量测试 (5用户权限(使用权限 (6升级安装卸载(平滑升级 (7日志相关(包括调试日志 (8软件功能的逻辑划分 功能上划分未能覆盖的代码逻辑,可以添加白盒灰盒用例; (9关联的功能 设计关联的测试的用例 (10可靠性,容错性 (11兼容性(浏览器,系统 (12安全性 (13性能(这里的性能是指,单个模块或者子系统的性能 总之 测试用例首先要能覆盖所有功能需求点, 然后搞懂软件处理逻辑, 可以找开发一起看测 试用例, 把没有覆盖到的代码流程相应的补充用例。 用例覆盖到这 2 点基本不会出现基本功 能的问题。 在此基础上,可以进行一些可靠性,容错性,兼容性等用例的设计,测试下软件的稳 转自:领测软件测试网 原文链接:

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1