第1章 自动化测试的好处
1.回归测试,降低测试成本
对于产品型的软件或生命周期长的项目,经常会有新功能的开发或需求的变动,对于新发布的软件功能,大部分都和上一个版本相近或相同,这些功能如果在上一 个版本之前已经实现了自动化测试,那么新发布的版本中,这部分功能就可以自动化测试实现,避免了重复测试的成本,也确保了软件的质量。
2.提高测试效率
一些测试用例手工测试是比较繁琐的,比如话单或协议字段的检查,如果是人工检查将是一件既繁琐又耗时还容易出错的工作,如果是自动化测试,测试就会变得轻松和容易很多。
对于检查点很多的测试用例,如果手工执行一步都需要停下来检查好几个复杂的检查点,测试的效率自然是非常低,使用自动化测试,设置好了输入条件和预期结果,只要点击按钮运行一下脚本就知道了复杂的测试结果。
3.易于发现软件的改动
自动化测试脚本可以重复执行,容易发现软件的任何变动。比如修复了一个TR后,引起原功能的改动,执行相同的脚本,可以通过测试轻易发现问题。
4.充分利用资源
自动化测试可以不需要人在现场的情况下自动执行,发布了一个新版本的软件后,可以在白天的上班时间进行新功能的手工测试,原有功能的自动化测试可以在晚 上或周末执行,第二天上班就可以看到执行的结果。这样充分利用时间资源,提高测试的效率,也避免了开发和测试之间的等待。
5.性能测试
关于尊严的格言警句 在一些压力大的性能测试中,人工是很难模拟的。在没有引入自动化测试工具之前,为了测试并发,研发中心再加上公司的其它部门上千号人在研发经理的口令“1-、2-、3!”的号召下,大家同时按下同一个按钮。这样的测试,虽然是模拟了并发,但需要消耗相当大的成本,想要测试一次也不容易。
在性能测试中使用自动化测试,可以轻易模拟并发,为性能压力测试提供了更好的方法。
6.将精力投入更有意义的测试
自动化测试减轻了很多重复的工作,我们有更多的时间去思考如何提高软件的质量,制定详细的测试计划,精心设计测试用例,构建更复杂的测试。对于我来说,这是自动化测试给我带来的最大的好处。
自动化测试的好处有很多,但并不意味着自动化测试可以取代手工测试,也不意味着任何的系统都适合自动化测试。自动化测试的意义并不是取代人在测试中的位置,而是将人从重复繁琐的工作中解放出来,做更有价值的测试工作。
第2章 自动化测试基本原则
2.1 适合做自动化测试的软件
很多公司都知道自动化测试可以提高测试的效率,但在知道这个道理的公司中大部分的公司都是以手工测试为主的,原因可能有很多,但最大的影响因素就是自动 化测试的成本。如果自动化测试的成本比手工测试的成本还大或者并没有比自动化测试占有太大的优势,公司自然不会选择自动化测试了。是否做自动化测试,主要 看成本的投入和效果的产
出是否值得。
1、不适合做自动化测试的系统
1)系统业务逻辑和交互过于复杂
拼魔方的技巧 如果系统业务逻辑和交互过于复杂,要实现自动化测试的成本非常高,工具开发和脚本编写的时间可能远远大于手工测试,这个系统就没有自动化测试的必要。
2)项目周期过短
如果系统的生命周期很短(半年内),即使很容易实现自动化测试,但自动化测试的使用率只有很短的时间或很有限的次数,这样的自动化测试也没有必要。因为前期脚本的编写和后期的维护都需要很多的时间,虽然自动化测试在功能测试的过程或回归测试的过程会节省一些时间,但如果自动化测试的脚本只是很短的生命周期,自动化测试的成本就非常的高了。
3)系统需求频繁变动
对于功能不稳定的系统,会由于这些不稳定因素导致自动化测试失败,自动化的测试结果也就变得不可信,这类型的系统也不适合使用自动化测试。
2、适合做测试化测试的系统草药学1-600攻略
适合做自动化测试的系统,通常是一些生命周期比较长的项目或产品,且系统功能实现自动化测试也较为容易,这样的项目使用自动化测试必然可以节省很多的资 源和成本。特别是一些在今后的几年间需要不断开发和维护的项目,需要重复的进行大量的回归测试,如果有完善的自动化测试脚本,回归测试就可以节省大量的时 间和精力了。对于一些增量式的产品,白天手工测试新功能,晚上或周末利用自动化测试脚本回归测试,可以达到资源使用的最优化,用很少的时间和很少的资源做 很多的事情。
简而言之,是否值得使用自动化测试,就要看它是否具有自动化测试的特点和高的投资回报率。
2.2 开始自动化测试的时机
如果是新的自动化测试工具的开发或研究,最好预留一个比较充裕的时间,时间太赶很
难设计出精品。如果想在功能测试阶段使用自动化测试,那么自动化测试架 构的设计最好能够与代码实现同步,否则如果等代码实现提交测试之后再做自动化测试工具的开发或研究,在功能测试或回归测试的过程中就被动了很多。
关于在项目的什么阶段开始自动化测试,由项目决定,对于需求相对稳定并且是基于成熟的架构上开发的系统,自动化测试脚本最好在功能测试开始之前编写,在功能测试阶段就可以使用已经编写好的脚本做功能测试了。抖音小程序
但我们平时遇到的项目,有很多是需求变化比较大的,或者是一些不够成熟的系统,这样的系统如果在功能测试之前编写好的脚本,很有可能不能在系统上正确运 行,大多还是需要手工执行才可以测试,甚至会在功能测试完后系统跟功能测试之前的系统会有非常大的区别。对于这样的项目,自动化测试开始得越早项目的成本 就越大,最好在系统的架构或需求相对稳定后再做自动化测试。
对于一些需要录制GUI界面 的功能的自动化测试,在页面的功能相对稳定之后再做自动化测试性价比会比较高,因为页面是最容易变动的部分,而且任何一个控件的修改都会导致自动化工具不 能识别控件,导致很多自动化测试脚本会跟着做大量的修改,增加了维护
的成本。当然,因为页面变化而引起的脚本的改动的大小,也跟自动化测试的架构和写脚本 的功力有密切的关系。
对于一些协议或接口相关的功能测试(比如:XML或socket接口等),是较为容易实现自动化测试的,封装好底层的协议提供给自动化测试脚本调用,即使是协议会有变化,改动起来还是很简单的,维护的成本相对较低。
总的来说,在软件功能达到相对的稳定,没有严重错误和逻辑错误后开始自动化测试,性价比是比较高的。
梦见掉头发 2.3 自动化测试的覆盖率
自动化测试的覆盖率是很多管理层所关心的,很多项目或产品的自动化测试目标之一就是自动化测试的覆盖率。从管理的角度来说,100% 的自动化目标只是一个从理论上可能达到的,但是实际上达到 100% 的自动化的代价是十分昂贵的。自动化测试覆盖率越高,测试脚本的维护成本也就越大。由于对每一个构建版本的需求变化的复杂度,你将花费更多的时间在变更测 试用例上以使他们能够正确的运行。
自动化测试的覆盖率的大小与自动化测试的成本有着很大的联系。自动化测试的覆盖率为多少比较恰当,也要看被测试系统的性质和测试的阶段。
在自动化测试设计的阶段,可以考虑先实现冒烟测试的测试用例自动化,冒烟测试的功能一般是系统的主要功能,是自动化测试设计必须首先实现的,而且通过实现这些功能,也可以检验自动化测试的架构是否合理。
在功能测试的前期,自动化测试脚本的覆盖率最好只是一些关键的并且是相对稳定的功能的测试自动化,用于冒烟测试或关键功能测试。
系统稳定后,如果系统是一个生命周期很长的系统,且测试的功能很容易实现自动化测试,这样的系统的自动化测试覆盖率可以考虑在80%以上。大蒜的功效与作用
但如果是一些时间很赶的项目,或者是一些比较难实现自动化测试的功能,也就没有追求高的自动化测试的覆盖率的必要。随着测试案例的增加,维护的成本也会相应增加,特别是一些GUI的测试,自动化比率越高,维护脚本的成本也就越高。
不要追求在很短的时间实现自动化测试,也不要追求100%的自动化测试覆盖率,积累经
验循序渐进的自动化测试,效果会更好。
第3章 自动化测试实现基本策略
自动化测试与软件开发本质上是一样的,利用自动化测试工具,经过测试需求分析,设计出自动化测试用例,从而搭建自动化测试的框架,设计与编写自动化脚本,验证测试脚本的正确性,最终完成自动化测试测试脚本(即主要功能为测试的应用软件)。
3.1 测试系统需求分析
任何测试的基础都是被测系统的功能,不管是手工的功能测试还是自动化测试或者是性能测试,都是基于系统的功能展开的。当测试项目满足了自动化的前提条 件,并确定在该项目中需要使用自动化测试时,我们便开始进行自动化测试需求分析。此过程需要确定自动化测试的范围以及相应的测试用例、测试数据,并形成详 细的文档,以便于自动化测试框架的建立。
很多公司都是将自动化测试和功能测试划分成两个 不同的team,自动化测试team的同事实现自动化测试工具的开发,功能测试team的同事向自动化测试team的同事提需求,自动
化测试team的同 事编写代码实现自动化测试工具的功能后提交给功能测试team的同事使用,这是当前非常常见的自动化测试的模式,毕竟每个人都有自己擅长的技能,某个人也 不可能面面俱到,通过这样的一种方式可能使自动化测试的门槛变得更低一些。自动化测试工具的开发和自动化测试的使用的确是可以由不同的角去承担,不过作 为自动化架构设计的人员,应该是对系统的功能或需求非常熟悉,同时具有良好的设计和开发能力,才可以设计出适合测试系统的自动化测试架构,否则开发出来的 自动化测试工具就只是简单的一个工具,某种程度上会增加维护的成本。
漂亮的自动化测试架构的设计是一个渐进的过程,但这个渐进是基于对功能熟悉的基础上,全盘考虑之后一点一点的搭建起来的。
3.2 自动化测试工具的选择
很多测试的同行或以前的老同事都会问,你们用什么自动化测试工具?几年前入门测试时跟着老前辈写自动化测试工具,后来因为兴趣偶尔玩一下当时流行的自动 化测试工具,再到现在毫无选择工具的余地设计自动化测试架构,越来越发觉自动化测试工具真的没有那么的重要。工具始终是工具,思想和架构才是自动化测试的 核心,同样的工具不同的人
使用会出现完全不一样的结果,而且,不管是什么样的自动化测试工具,原理都有异曲同工之处。所以,不需要把工具看得那么重要,而 是把怎样使用工具,怎样利用工具为你服务放在首位。也就是你的思想位于工具之上。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论