没有合适的资源?快使用搜索试试~ 我知道了~
自动化测试异常处理及用例管理.doc
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 144 浏览量
2021-10-12
07:35:39
上传
评论
收藏 582KB DOC 举报
温馨提示
![preview](https://dl-preview.csdnimg.cn/31767790/0001-1454226cb708eb1841d97fc99f5d76b0_thumbnail-wide.jpeg)
![preview-icon](https://csdnimg.cn/release/downloadcmsfe/public/img/scale.ab9e0183.png)
试读
17页
自动化测试异常处理及用例管理.doc
资源推荐
资源详情
资源评论
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![application/x-zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/release/download_crawler_static/31767790/bg1.jpg)
.. -
测试用例的前置条件和后置条件
除了第二点中谈到的数据需要准备外,在测试用例这个 ,必须有一些条件满足,您才能开场执行它。比方准备一个初始设置条件下的
浏览器和已安装过老版本该软件的 系统。这些可重用的准入条件,可以考虑不作为特定用例的 ,而是把它提取出来,作为
或叫 。
对于后置条件或 ,往往我们用它来做一些处理或恢复,比方在上面的取款例子中,如果我们要用一样的 重复测试,在
正好取完所有金额,余额为零的情况下,可以通过一些步骤或数据库脚本重置 余额。同样,您为某个用例设置浏览器禁用了 ,执行完
该用例后,是不是也是需要回复到默认设置的状态呢?
集中的把这些步骤整理成一个相对独立的操作单元,具体用例中只要引用就可以了,这样会便于对用例的理解和在多处复用。
顺便说一下,对于一些类似软件运行环境的条件,比方安装和配置测试中,需要 种操作系统和 种浏览器的组合等,我们可以把他放在
这个 上来,不用写多个用例,只是在测试方案和执行的管理系统中作为测试集的一个环境参数,恰当地表达出来就可以。
常用业务操作 !"
对于一个大型的应用,比方银行系统,开发和测试工作是长期的,持续的一个过程,这样的系统很适合引入自动化测试。它业务逻辑复
杂,测试技术性要求高,往往使用了不同厂商的工具和多种脚本语言〔如 #,$# 等〕,也存在了很多可用的遗留脚本。
这些完成一些预定业务操作的脚本单元,是可以直接借用的。为了在公司和产品层面,管理好这些可复用的资源,一种好的式是给它们标
上号,如 %&'()%*(+%,集中管理起来,以后的用例中只要调用即可。
举例来说,在银行业务测试中我们,需要模拟和银联的接口,让测试 向外汇款,取得响应信息,并保存结果,这可能是个复杂而底层的
处理过程,对一般员工是不需要,也没有权限去深入掌握的。这时,将他们包装成一个个 # 脚本或小工具,做好使用说明和统一建档,在以后
的工程测试中,只要调用就可以了。如此,可以大大提高各个有相关接口的模块的自动化测试工作效率。
根据以往工作中常见的一些问题,对于如写好测试用例〔不仅针对自动化测试〕,做以下做几点补充:
推荐 不推荐
将用例的容描述清楚,强调怎么操作,验证什
么,然后期待的结果是什么。
$ 需求和设计文档中的容;描述成:什么条
件下,逻辑会是怎样。这样对测试用例的阅读
和执行人员,不具有可操作性。
期待的结果要写具体,如:系统反响是什么;
结果数字是多少;用户被带到什么页面;显示
什么成功信息;后台或数据库中该记录的修改
后结果是怎么样的。
描述成:〞验证系统返回正确结果“;〞页面元
素显示跟 一致“;〞操作成功“等比拟抽象
的说法。
业务逻辑性较强的应用软件,做到以业务流为
主线,来组织用例。
以页面形式组织用例。
以 *、,、测试类型、根本业务
流、备选业务流的树状构造形式,分层次组织
用例;使用用例管理工具。
- 格式的扁平组织构造,不利于管理和阅
读。
用一个属性字段,建立用例和 等文档的某
个章节间的映射。
无法和需求对应,以后难以计算用例覆盖率,
测试执行覆盖率。
. . word.zl-
![](https://csdnimg.cn/release/download_crawler_static/31767790/bg2.jpg)
.. -
每个 *、,、特定业务的一组测
试用例,之间做到独立、没有耦合。
用例之间有依赖,无法做到:挑选 (.的用例
做回归测试。
在时间和本钱允的情况下,尽量做到:用例粒
度为“一种不同的操作,得到不同的结果,就单
独写一个用例“。
在用例中的操作步骤中,甚至期待结果中,仍
然存在条件分支。
对于复杂的业务操作过程,如〞一次顺序的表
单签核过程“和〞一次完整的信贷手续“,单独增
加一些贯穿整个业务流的大型测试用例。
对于一个长业务操作,只存在比拟零散的细节
用例。
将用例分优先等级,便于在回归测试时挑选核
心业务或用户操作密集的用例。
用例没有优先级和重要程度的定义。
/
自动化测试 用例设计 的原那么
很多公司在实施自动化测试的过程中,往往会把所有的手工测试用例作为自动化测试用例,并且直接进展脚本的
开发工作,甚至有些公司不写自动化测试用例,直接想当然地开发测试脚本,这些都是极其不规的做法,甚至很有可
能是导致最后自动化测试工程失败的最大原因。那么问题就来了,为什么不能使用手工测试用例完全替代自动化测试
用例呢?有以下几点原因,同时也是自动化测试用例的设计原那么
0/原那么 ):自动化测试用例的围往往是核心业务流程或者重复执行率较高的。
在选取自动化测试用例围时,很多测试工程师或者上级领导可能心里会过分依赖自动化测试,会认为自动化测试
就应该覆盖所有的手工测试用例,自动化测试的覆盖率就应该到达百分之百。其实恰好相反,这样的想法往往会导致
自动化测试最终失败。在一些大型工程中,往往测试用例的数量会很庞大,而且如果遇到一些繁杂的被测程序〔特别
是 1 架构〕,脚本开发工作往往会相当耗时间,并且很多测试用例甚至根本就不能通过自动化来实现。举些例子,
现在很多公司自动化测试都是刚起步,对自动化测试的了解程度只是停留在字面上,在公司对测试也不是非常重视的
情况下,当然不太愿意去花精力招一个具有自动化测试开发经历的工程师,很多还是停留在使用工具的录制回放功能
来完成自动化测试。正是存在这样的技术限制情况下,往往在实施中,会出现很多录制回放不能解决的问题,测试工
具完全无法识别测试对象,无法识别一些特殊的加密测试控件。还有,如果工程的变更频率,测试用例数量大的话,
增加了后期的维护工作量等,都是造成最终失败的一些隐患。投入越大,损失越大。因此,往往我们会选取最核心的
一些业务路径或者是重复执行率较高的一些手工测试用例进展自动化测试,这样能够充分发挥出自动化测试的优势。
0/原那么 +:自动化测试用例的选择一般以“正向〞为主。
手工测试用例分正常情况和异常情况,在设计的时候,可能往往会去设计很多异常情况来验证程序是否有 Bug,
并且一个正常情况的测试用例往往会对应几十个非正常情况的测试用例,而每种异常情况的测试用例都会有各种各样
的预期结果。在自动化测试中,很多人喜欢将正常情况称为“正向〞;反之,异常情况那么称为“反向〞。下面,我们试
想以下,如果将这些异常情况全部转化、反响到自动化测试脚本中,那肯定需要非常繁琐的判断才能做到。这个对于
自动化测试工程师来说,其现有的工作量还是今后的脚本维护量都是不可小视的。对于整个自动化测试工程来说,如
果每个异常情况都要写进脚本中,那真的是花了大价买一堆小东西,小东西真正能发挥大作用的毕竟很少。因此,真
正在自动化测试工程实施中,往往会舍弃反向用例,个别比拟重要的除外。使每个东西都能发挥其最大的作用才是企
. . word.zl-
![](https://csdnimg.cn/release/download_crawler_static/31767790/bg3.jpg)
.. -
业最想看到的。功能自动化测试主要还是用于回归测试,回归测试的目的就是保证新增功能后老功能是否能够正常继
续运作。而自动化测试那么是让测试人员从繁琐又枯燥的重复手工测试中解放出来,这就是目的和目标。
原那么 :不是所有手工测试用例都可以使用自动化测试来实现的。
这里纠正多测试从业人员的一个错误观念,刚接触测试自动化的普遍都会认为手工测试用例全部要转化为自动化
测试用例,但是在真正实施的时候,却发现很多测试用例是自动化无法实现的,或者有些测试用例根本就没有必要去
自动化的。例如,有些用例会牵涉到硬件设备辅助的,最简单的例子就是用例执行过程中需要使用刷卡机才能获取卡
号信息〔如果有技术能力,当然不排除自行开发接口供测试工具调用,但毕竟能有技术实力做到这一步的不多,能有
这样的重视程度的更不多〕;再比方,有些测试用例是需要与合作机构进展互动联调,联调时是需要和对实时沟通,
以及根据具体情况给予响应的,这些情况多数还是只能使用手工人为地来完成。当然,决定是否转化为自动化测试,
必须事先有一个规文档来定义哪些是需要转化为自动化测试哪些是不需要的,否那么测试工程师就会不知所措,没有
一个标准。一旦有了这个标准,自动化测试工程师就可以格按照文档里的流程去完成需要转化局部的自动化测试用例
的脚本开发工作了。
原那么 :手工测试用例可以不用回归原点,而自动化用例往往是必须的。
很多有经历的自动化测试从业人员一定有这样的经历,很多时候脚本写完后,第一次执行没有任问题,而第二次
执行时立刻就会报错,原因就是没有回归原点。所谓回归原点就是执行的测试用例最终需要恢复其在执行前的初始状
态,如果没有回归原点,就会把此脚本称之为死脚本。举个最简单的例子,比方添加用户功能,我们都知道每个用户
名都是唯一的,当写完一个添加用户的脚本之后,执行第一次没有问题,因为执行前此用户还不存在,但是当执行第
二次时,程序就会出现用户重复而报错,此时这个添加用户的脚本就失去了它的价值,在这种情况下,我们就需要在
自动化测试用例的最后加上删除这个用户的步骤,这样在下次执行用例时就不会出现用户重复的情况了。当然,除了
回归原点,还可以使用另一种式进展,那就是初始化数据,比方 2* 机取款,假设需要执行取款 )(( 元的操作,而银
行卡余额是 )+( 元,当测试脚本第一次执行时可能没有任问题,但是第二次系统就会报余额缺乏,这样就成为了死脚
本,解决案有两种:一种是直接进展初始化数据,每次执行用例之前都重置下余额〔只需大于 )(( 即可〕;第二种法
可以在用例执行前,先查询下余额是否大于 )((,假设大于等于那么继续,假设小于那么做一笔充值 )(( 的操作,这
样即可解决。两种式可以看具体情况使用,数据初始化便,但有时候初始化之后可能会影响到其他自动化测试用例的
执行,而第二种式相对在脚本上需要稍微花点功夫。终究使用哪种式还需要具体情况具体分析。总之,在执行自动化
测试用例之前做好数据准备,这也是自动化测试的关键步骤。
原那么 3:自动化测试用例和手工测试用例不同,不需要每个步骤都写预期结果。
在手工测试用例的设计过程中,几乎每一个测试步骤都有一个预期结果。但是,在自动化测试用例的设计中并不
采用,在自动化测试用例中,只有准备在测试脚本中设置成检查点的步骤才有预期结果,其他所有的步骤只将它看作
一个步骤,这样做的好处是一目了然、目的明显、层次清楚,以后写测试脚本直接跟着自动化测试用例就行了。因为
经过前面的探讨应该已经知道,自动化测试中并不是所有的东西都需要验证的。所以,作者在前面的章节中也提到过,
根本上手工测试用例多多少少都要进展一些转换的,就是因为它们之间的格式是不一致的。举一个简单的例子,假设
需要设计一个注册页面的自动化测试用例,有 )( 几个表单需要填写,在手工测试用例中,每个表单的填写都一定会有
预期结果,因为它确实在检查每一项为哪一项对了还是错了,只是用的是你的眼睛在检查而已,所以速度非常的快,
甚至你自己潜意识都忽略了其实你已经检查了。但是,在自动化测试中,我们知道如果你要检查,那一定需要写代码,
如果每项都检查,那代码量有多大是可想而知的,不是说做不到,只是这样做根本不符合自动化测试的特点。所以,
绝大局部时候,这些在自动化测试中可有可无的检查,我们全部“不检查〞,只当做一个业务流程和步骤,是不需要设
立预期结果的。
难以对于 4 样式或 4 逻辑进展断言
. . word.zl-
![](https://csdnimg.cn/release/download_crawler_static/31767790/bg4.jpg)
.. -
以上图为例,有一个 4 样式类的缺陷〔左侧菜单树的根节点“〞下面多出来一条虚线〕和一个 4 逻辑类的缺
陷〔右侧用户列表只有一页,但“下一页〞和“最后一页〞图标依然是可以点击的,即没有灰显〕。此类缺陷即使对于经
历丰富、心思缜密的测试人员,在人工测试时也是很可能发现不了的,并且在自动化测试过程中也很难进展断言。
即使存在上述问题,测试脚本中是否有充分的断言,依然是评判自动化测试有效性的一个重要指标。但实施过自动化
测试的人应该都会有这样的体会:“大局部断言在大局部情况下只是佐证软件是运行正常的〞。
当然,所有人都应该是非常期待看到这样的结果,毕竟谁也不希望每次回归测试时都是用例大面积不通过。只是辛辛
苦苦写这些断言语句的测试人员心里未免有些“小遗憾〞。
本系列上篇文章中谈到“很多人一提到自动化测试脚本,马上就想到需要提供录制工具〞,但如果换个角度思考,很可
能就是“柳暗花明又一村〞。
在这里,我们同样换个角度思考,假设我们的自动化测试主要目标是为了证明软件运行正常,那么我们会怎么做?
笔者这边的一个经历就是“按照完整的业务流程来组织测试用例,只对少量、必要的关键点进展断言〞。以“租户对虚拟
化资源的申请使用〞为例,来具体看看测试用例的组织式:
) 新租户注册;
+ 管理员登录系统,对注册租户进展审批,然后退出系统;
审批后的租户登录系统;
租户申请所需要的虚拟化资源〔比方,(5 硬盘、+ 核 4、+5 存〕,然后退出系统;
3 管理员登录系统,对租户申请的资源进展审批,然后退出系统;
6 租户登录系统,在已申请资源的根底上创立安装指定操作系统的虚拟机;
7 断言虚拟机是否创立成功;
8 租户退出系统;
9 管理员登录系统,删除租户;
)( 断言租户之前申请的资源是否被完全释放;
)) 租户再次登录系统,断言是否无法登录;
上述测试用例就是按照完整的业务流程进展组织,并且只对少量关键点〔7、)(、))〕进展断言,如果整个用例可以
运行通过,就能证明这个业务是没有问题的。
另外还有一个值得考虑的现象,就是相对于自动化测试而言,一个优秀的测试人员在人工测试时是如判断功能正确与
否的呢?他不会死板的只盯着某几个输入域的值,他一定还会同时关注页面上所有数据的正确性、会更加关注业务流
程是否正确、会更敏锐的发现页面样式或 4 逻辑类的缺陷。
为了兼顾“证明软件正常运行〞和“人性化的识别软件缺陷〞,一个优秀的测试工具应该考虑提供以下多种断言机制。
一、控件级细粒度断言
即前面提到的最常见的断言式。在测试过程中,可以在任位置增加断言脚本,来判断页面指定控件是否存在、控件显
示值是否为预期结果等。通常建议只对关键校验点进展断言。
二、页面级粗粒度断言
. . word.zl-
剩余16页未读,继续阅读
资源评论
![avatar-default](https://csdnimg.cn/release/downloadcmsfe/public/img/lazyLogo2.1882d7f4.png)
![avatar](https://profile-avatar.csdnimg.cn/default.jpg!1)
wsbhm62
- 粉丝: 7
- 资源: 21万+
![benefits](https://csdnimg.cn/release/downloadcmsfe/public/img/vip-rights-1.c8e153b4.png)
下载权益
![privilege](https://csdnimg.cn/release/downloadcmsfe/public/img/vip-rights-2.ec46750a.png)
C知道特权
![article](https://csdnimg.cn/release/downloadcmsfe/public/img/vip-rights-3.fc5e5fb6.png)
VIP文章
![course-privilege](https://csdnimg.cn/release/downloadcmsfe/public/img/vip-rights-4.320a6894.png)
课程特权
![rights](https://csdnimg.cn/release/downloadcmsfe/public/img/vip-rights-icon.fe0226a8.png)
开通VIP
上传资源 快速赚钱
我的内容管理 展开
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助
![voice](https://csdnimg.cn/release/downloadcmsfe/public/img/voice.245cc511.png)
![center-task](https://csdnimg.cn/release/downloadcmsfe/public/img/center-task.c2eda91a.png)
最新资源
- 基于74LS161+ 74LS192芯片实现倒计时定时器Multisim仿真源文件,Multisim10以上版本可打开运行
- 科大讯飞语音引擎 jar包 demo,科大讯飞语音合成引擎3.0,支持4.0系统以上,文字转语音输出.zip
- Java架构面试笔试专题资料及经验(含答案)SpringBoot面试Linux面试专题及答案 合集.zip
- 头歌c语言实验答案tion-model-for-ne开发笔记
- docker配置使用-model-for-networK开发demo
- docker配置使用vaWeb-mas笔记
- c语言连接两个字符串-mas开发笔记
- 俄罗斯引擎yandex进入x-master 笔记
- 头歌c语言实验答案el-for-network-ids-ma笔记
- 一个delphi写的连连看
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
![feedback](https://img-home.csdnimg.cn/images/20220527035711.png)
![feedback](https://img-home.csdnimg.cn/images/20220527035711.png)
![feedback-tip](https://img-home.csdnimg.cn/images/20220527035111.png)
安全验证
文档复制为VIP权益,开通VIP直接复制
![dialog-icon](https://csdnimg.cn/release/downloadcmsfe/public/img/green-success.6a4acb44.png)