• 0
  • 0
分享

1.png

重新认识自动化测试

我从事软件测试工作以来,第一次知道自动化是 15 年年底,听大佬说 QTP 可以录制脚本然后自动化回放,测试效率很高,当时心向往之。不过当时技术比较菜,而且对工作也比较迷茫,听过就忘记了。

大概 16 年时候,测试圈子自动化测试开始火爆了起来,当时基于 selenium 的 UI 自动化测试特别火爆。圈子里讨论,培训班推广,很多关于基于 selenium 的 UI 自动化测试的技术文章和书籍开始不断涌现。

我本人是 17 年年初才开始学习自动化测试并且尝试在工作中应用的,确实在回归测试和造数据方面,给了我很多的帮助,当然由于比较早吃螃蟹,在后面跳槽找工作时候,涨薪幅度也挺大。

大概 18/19 年时候,各种自动化测试平台开始在各技术大会、技术沙龙以及技术社区被大家讨论了起来。几个大厂的测试平台之类的最佳实践也开始被大家模仿借鉴学习,这一点大厂做的还是很好的,最起码指引了部分迷茫同学的技术提升和职场发展方向。

差不多 20 年底 21 年时候,我已经是个测试圈子的老鸟了,开始带团队,负责部分招聘和技术面试工作,也会帮业务线的测试同学交叉面试一些候选人。我发现自动化测试已经成了业务测试同学的面试必问技能。前几年大家觉得功能测试最多只负责功能+接口,自动化测试需要有专门的岗位,而近几年,自动化测试成了业务测试的必备技能。我个人认为原因有如下几点:

  1. 软件工程理念在实际工作中的不断深入;

  2. 业务迭代加速以及系统架构不断复杂化倒逼测试提升效率;

  3. 自动化测试工具/框架/技术实践不断丰富成熟以及求职市场的整体水平提升;

其实自动化测试的理念很早就被提出来了,国外也有很多的实践,国内相对较慢,但近几年测试圈子整体的基础技术建设也在快速发展。在我现在的认知里,自动化测试的能力可以算是测试团队的基础技术建设了。

因此,我的建议是,无论是刚入行的萌新,还是之前一直做功能测试的同学,为了更好的职场发展和增强竞争力,具备做自动化测试的技术能力也需要快速提升起来。

新手落地自动化测试

在讨论新手从零到一落地接口自动化测试之前,我想先抛出我的几点建议:

  • 从零开始,不要直接去学习所谓的自动化框架;

  • 学习框架之前,很有必要学习网络协议和编码知识;

为什么这么说?新手一般技术基础不太扎实,且没有太多编码实践,直接学习框架特别容易一步一个坑。

从零开始学习落地接口自动化或者其他自动化测试,我更建议从易到难的去落地实践,这样一方面可以在日常工作中优先保证工作的完成,提升工作效率;另一方面就像打怪升级一样,从易到难去学习提升自己,并不断优化自动化测试在工作中的实践。从易到难落地接口自动化测试,大概可以遵循如下几个步骤:

  • 学会用工具进行接口测试(如 jmeter/postman);

  • 学会用持续集成工具(如 jenkins)将接口测试脚本批量执行;

  • 学会诸如 git/gitlab 等版本和源代码管理的工具,便于团队多人协作;

  • 学习一门编程语言,利用自动化测试框架将工具脚本转化为代码脚本;

  • 学习将公共部分封装,优化代码结构,提高写代码脚本的效率,降低维护成本;

  • 学习数据参数化管理的方法,可以从 Excel——配置文件——数据库——造数工厂这个方向迭代;

  • 尝试按照业务线和测试场景区分脚本集合,然后引入 mock,降低服务间的调用依赖,提高执行效率;

  • 开始画大饼,造轮子,搞 KPI,开发自动化测试平台;

自动化测试成熟度模型

本文第二部分的内容来源于我前几天写的文章:《从零到一落地接口自动化测试》,这里以从零到一落地自动化测试的几个步骤,来谈谈自动化测试的成熟度模型。

初级阶段-测试半自动化

先利用工具将日常费时的手工测试部分转化为半自动化(如 postman/jmeter/jenkins),不要考虑什么框架或者 CICD 等高大上的东西,先解决部分效率问题,才能有时间和资源投入后续的建设。当然这个阶段更适用于初创企业或者小型公司的测试同学。

中级阶段-回归测试自动化

有了前期的部分建设,接下来可以将日常的提测冒烟测试、系统测试阶段的主流程回归测试以及部分造测试数据的过程转化为自动化。这个过程中一方面需要培养提升建设团队同学的技术能力,另一方面为自动化测试的大范围落地做铺垫(毕竟很多公司自动化测试看不到短期效益就变成了纯粹的 KPI 然后不了了之)。

注意:上面我说的都是测试自动化,并不是自动化测试。测试自动化指的是先将日常手工测试比较费时且重复度较高的部分转化为利用工具执行,这样做是为了提高效率,解放人力资源,也是为了打好基础,顺带让领导知道,做这些事对团队有长期价值的。

高级阶段-大范围自动化测试

到了高级阶段,我个人认为就可以开展大范围的自动化测试了。这里的大范围并不是说完全不需要手工测试,而是按照自动化测试的纺锥模型(不是金字塔模型),按照 UI-10%/API-70%/UNIT-20%的占比去不断建设和落地。

2.png

当然,这个阶段可以开始尝试测试左移的实践,测试同学去做更多具有创造性和探索性的工作,比如:

  1. 花更多时间在需求阶段,包括需求分析和需求评审,做好需求阶段的质量卡点;

  2. 设计更高效的自动化测试流程框架,提升测试用例的有效覆盖率(正交实验法);

  3. 推动研发同学实践单元测试,测试同学提供 case 并评审验证,研发同学负责落地;

  4. 建设质量度量相关的事情(为了解决问题验证效果而度量,并非为了度量指标而魔改自动化);

成熟阶段-自动化测试流水线

有了前面三个阶段的技术建设和用例沉淀以及不同团队间的协同配合,这个阶段可以考虑将自动化测试融入到企业的自动化交付流水线中。大致思路如下图:

3.png


作者:佚名

原文链接:https://xie.infoq.cn/article/db27ba6a85b9ce76489231be0

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 36氪独家获悉,由罗永浩联合创立的交个朋友公司正在布局海外电商培训业务,主要由‘交个朋友海外事业部’和基于Tik Tok生态下的‘交个朋友电商学苑’承担。并且,36氪注意到杭州交个朋友教育科技有限公司已申请注册“交个朋友海外电商学苑MAKING FRIENDSE-COMMERCE ACADEMY”商标,国际分类为广告销售、教育娱乐,当前商标状态为申请中。同时,36氪在交个朋友海外电商学苑的抖音官方蓝V发现,交个朋友的核心名师已陆续开始为该课程代言。此外,交个朋友高管层向36氪透露,交个朋友确有布局海外电商培训业务,并将其定位为公司未来的重点项目之一。因此,该项目得以集合到公司内外大量顶级教学教...
            0 0 845
            分享
          •       沐沐在之前的工作中,主要使用Jenkins构建测试环境,因此为了节省回归测试的时间,就同步在Linux上搭建了JMeter+ant+Jenkins的接口自动化框架;主要用于环境构建后回归测试、定时构建、迁移环境后回归验证等测试场景。以下内容为当时搭建环境时的笔记,希望有需要的朋友们可以作为参考。一、安装JMeter1、下载jmeter压缩包:http://jmeter.apache.org/download_jmeter.cgi2、进入usr目录:cd usr3、创建文件夹:mkdir JMeter4、上传文件夹到服务器:apache-jmeter-5...
            2 0 4816
            分享
          •   当IT变得越来越敏捷,商业上的变化率需要更快地采用敏捷技术。  IT行业不止是有软件开发。我们不仅为我们的投资商创建基于软件的解决方案,也将解决问题的方案发行到生产环境中,一旦发布到生产环境里以后,我们还在生产环境里操作和维护那些方法。也有如企业架构,原型管理,数据管理还有其他跨解决问题方案的结构功能点并行发生在软件开发和运行中。最近,我决定研究这个问题:这些IT功能有多有效?我发现这其中有很多改进的空间。  从2014年的9月份到11月,我做了一个线上的调查,探寻几个常见的IT功能的有效性。该调查有117个回应者,其中大概一半的人在IT行业有20年或20年以上的经验(88%的人有10年或...
            1 1 1641
            分享
          •   Locust介绍  Locust是一款使用Python开发的开源性能测试工具,支持分布式,可在多台主机上对系统持续发送请求,与Jmeter、LoadRunner的等压测工具使用线程的方式模拟用户请求不同,Locust是使用协程的方式模拟用户请求,协程的上下文切换是由自己控制,当一个协程执行完成后会主动让出,让另一个协程开始执行,切换是在用户态完成的,而线程切换是受系统控制,是在用户态与内核态之间切换,所以协程上下文切换的代价远比线程切换的代价小的多,因此Locust可以达到更高数量级的并发。  Locust安装  需要先安装python3.6以上版本,然后再安装Locust。  pip&n...
            0 0 1229
            分享
          • 1、双击jmeter.bat文件,进入jmter界面,如下图;2、右击测试计划--添加--线程(用户)--线程组,添加一个线程组,如下图所示;3、右击线程组--添加--取样器--HTTP请求,添加一个HTTP请求,如下图所示4、根据给定的接口文档或者自己抓包获取的URL相关信息,填写以下信息:5、示例URL:https://baidu.gh.cn/baidu.service/LoginService/Login(此网址为错误网址,仅作举例使用)Request Method(请求方式): POSTjmeter内填写以下信息(如下图):协议:https服务器名称或IP:baidu.gh.cn路径:...
            0 0 5754
            分享
      • 51testing软件测试圈微信