8年测试工程师,关于UI自动化测试心得 --- 送给迷茫中的你

目前项目组的所负责的系统需求较多,测试案例数量也较多,测试场景复杂,测试数据制作复杂,并且有部分系统已经趋于成熟,所以打算开始进行UI自动化测试。

UI自动化测试其实是一门【水】很深的工作,因为UI自动化测试是需要根据前端页面元素,也就是HTML脚本来进行元素提取、操作、验证的测试流程,另外再加上项目的测试环境软件硬件的因素,在编写自动化测试脚本的时候需要考虑到很多的情况出现而要去判断当前页面出现的元素到底是什么情况,不然脚本的稳定性很不好,维护工作也会非常的高。另外在编写自动化脚本的时候,你会慢慢的熟悉你项目系统前端页面的代码,当下很多前端开发人员在制作新的项目前端页面时都会直接用现成的组件生成,这种HTML代码会使你开发脚本时难上加难,因为里面的标签命名根本就是乱来的(可以说是看得出一个前端开发人员的水平?)

目前项目组中所负责的需求分为两种:手机端(Native+H5),PC Web端。

因为我们是属于App的一个渠道方,Native方面并不是我们组内人员开发的(其实主要大公司在代码方面管得很严无法拿到Native的iOS和Andriod的代码所以这个需要和他们管沟通,不然无法做App的UI自动化),我们的前端开发主要做的是里面的H5页面,并且手机端的需求现在还经常有变化,所以手机端的UI自动化还不纳入UI自动化的执行范围,我们主要做的是PC Web端的UI自动化。

这篇文章(其实可以说是笔记)主要来讲一下我在做这个项目的UI自动化测试的过程以及心得。

文章主要讲的是:介绍UI自动化、组内UI自动化的架构、测试脚本的编写规范/心得


     ·  什么是UI自动化测试

  1. UI自动化测试,指的就是使用工具或者脚本对需要测试的软件的前端界面在预设的条件下和已经的测试数据下运行系统或者应用程序,并获取其前端页面显示的数据结果进行校验,评估得出测试结论。
  • UI自动化测试可用于哪里
  1. 基于测试渠道可分为:手机App、Pc web端、手机Web端等;
  2. 基于测试阶段可分为:冒烟测试、回归测试、生产验收、兼容性测试
  • 为什么要使用UI自动化测试
  1. 目前测试案例数量过多导致人工执行测试案例耗时过长,并且会出现无法执行完该执行的测试案例导致版本无法按预期上线;
  2. 案例的步骤繁琐,场景复杂,制作测试数据的过程复杂,导致人工执行时间过长;
  3. 需求简单,无前端功能开发的需求可以使用UI自动化进行测试并得出结论;
  4. 可以帮助开发人员进行自测。
  • 哪些测试可以执行UI自动化
  1. 已经比较成熟的项目,暂无任何大的改动需求的项目;
  2. 人工执行耗时长,流程繁琐的项目;
  3. 单纯的数据校验,列表功能校验;
  • 怎么执行自动化测试
  1. 开发提测前自用,配置环境和工具,下载脚本执行,可通过测试报告查看执行情况和结果;
  2. 冒烟测试中,测试在开发提测后执行,通过测试报告查看执行情况和测试结果;
  3. 回归测试中,测试人员执行执行纳入回归测试的测试脚本并执行
  4. 生产验收,UI自动化测试脚本可用于生产验收中,无须手动操作就可验证生产的情况。
  • 哪些可以做,哪些不能做?

*验功能不要验样式

ui自动化是无法识别你当前页面的图形形状以及颜色这类,就算是兼容性也只能从功能层面来验证,当然除非使用了图形识别组件这类功能的话另说。

  • UI自动化测试的利与弊

利处:快捷、方便、无须手工操作

  1. 对回归测试来讲一般情况下,回归测试里面的案例都很多都是之前的版本需求中的案例,在迭代多了之后回归测试中的案例就会慢慢的增加,到最后就会出现一个在封板之后执行回归测试案例时会执行不完的情况,使用UI自动化测试之后,以前的回归测试案例可以不需人工执行,等脚本执行完之后查看脚本测试报告和截图,成功失败一目了然,然后测试人员可以把注意力放在了当前迭代的需求中。
  2. 对于冒烟测试来讲(无前端改动的需求前提下),开发提测前都需要进行自测,他们可以在电脑上配置好UI自动化测试的环境后,利用工具自己执行进行自测;测试人员也可以利用脚本在开发提测之后使用进行自测。

弊端:脚本编写成本高、案例开发时间长、需要长期维护

  1. 一脚本编写成本高主要是分为要懂代码,对系统熟悉程度高,懂得一些编程的规范;为什么要懂代码?这里说的并不是说要非常厉害的那种,主要说的是最起码要可以阅读html、Js、Python、Java等,因为在对页面元素进行提取的时候你必须要根据Html页面上的代码来写的,这种基础的知识还是需要有的;对系统熟悉程度高是指的是你很熟悉你要写脚本的系统的业务流程很熟悉,包括他正常情况流程怎么走的,出错情况下会是怎么走的,会有什么提示这些你都要知道,因为这些场景都必须在写脚本的时候考虑进去,从而提升你脚本的稳定性,减少维护成本,为什么懂编程的规范其实和上一条差不多,主要是提升脚本稳定性,减少维护成本,后面脚本的编写心得会讲一下这个。
  2. 部分案例开发时间长,主要说的是一些场景比较复杂的流程,和数据制作的过程比较繁琐,需要你不停的调试你自己的脚本。
  3. 长期维护是必须的,因为你的系统的一些需求可能会使其他功能有变化,这个时候你的测试脚本需要考虑到这些场景的时候,你就要去修改你的脚本了,另外还有就是你的数据,有时候系统原因或者你的测试数据是其他关联系统的导致数据失效了,这个时候你必须保证你的数据是有效的,所以必须有个前置步骤来检查你的数据,这个后面如何维护数据会详细再写一下。

项目结构

目前自动化项目处于初期试实行阶段,并没开发得很强大的功能,因为首先要保证可以走得通走得稳,并且每个测试同学都可以用的前提下去开发的,所以采用的是Python 3.6+ Robot Framework Ride + Selenium2Library(PC Web)这一套比较传统的框架,代码由GitLab上管理,其实这一套框架即使是没什么代码基础的测试同学或者还是懂代码的测试同学也好,用起来也是非常的方便的。

有AppiumLibrary,针对手机端做自动化的,但是目前手机端做起来比较困难,暂时不考虑,这里也不先写。


测试脚本编写规范

  • 案例的选择

以下三点不做:

随便点一下就能验证的不做;

一条案例多个验证点的不做;(这种案例本来就有问题,必须把这种案例拆分)

界面图形验证,图片验证,颜色区分不做;(有过要我验证报表图形的,折线图扇形图这种,其实可以通过验证时截图)

以下两点必做:

前期数据准备步骤复杂流程长;

一个验证点的步骤复杂流程长;

  • 数据的管理
  • 脚本稳定性

    下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!å¨è¿éæå¥å¾çæè¿°

最后: 可以在公众号:程序员小濠 ! 免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!喜欢软件测试的小伙伴们,可以加入我们的测试技术交流扣扣群:310357728里面有各种软件测试资源和技术讨论)

Guess you like

Origin blog.csdn.net/IT_LanTian/article/details/121423668