一文让你了解UI自动化测试

测试都起什么作用 - 是项目的保险,但不是项目的救命草;测试无实际产出,但作用远大于实际产出;测试是从项目维度保证质量,而不是测试阶段。

UI自动化(下面简称自动化) - 基于UI进行自动功能测试,以Web端作为例子,一般的UI功能自动化都是基于HTML的Dom内容进行操作,一般都是使用webdriver + JavaScript的方式进行,目前最流行的一套基础框架就是Python + Selenium。

什么时候进行脚本开发 - 很多测试人员或者项目负责人都认为,自动化测试一般都在项目稳定之后才使用脚本对项目进行稳定性测试或者一些回归测试中,但随着项目组织架构的完善和目前大环境太卷(?)了,其实每个迭代的新需求都可以直接使用自动化测试来进行,前提是需要:

1. 开发人员需要尽早提供完善的Dom结构内容

2.测试组全部人员都需要具备脚本开发能力。

自动化脚本只有20%的作用,最重要的是测试案例的选取,一切的测试依据都来自于测试案例,记住自动化的用处,是用来找快速找缺陷的。

目前项目组的所负责的系统需求较多,测试案例数量也较多,测试场景复杂,测试数据制作复杂,并且有部分系统已经趋于成熟,所以打算开始进行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,针对手机端做自动化的,但是目前手机端做起来比较困难,暂时不考虑,这里也不先写。

测试脚本编写规范

  • 案例的选择

以下三点不做:

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

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

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

以下两点必做:

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

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

  • 数据的管理
  • 脚本稳定性
总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

      视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/343494.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

贪心算法详解

文章目录 前言一、什么是贪心算法二、贪心算法的特点1.贪心策略的提出2.贪心策略的正确性 三、学习贪心算法的方向总结 前言 在本次文章中我们将会详细介绍贪心算法的相关内容 一、什么是贪心算法 贪心算法:在解决问题时,每一步都选择最优解&#xff0…

K8s(九)持久化存储PV与PVC

PV和PVC PV 和 PVC 之间的关系是一种动态的供需匹配关系。PVC 表示应用程序对持久化存储的需求,而 PV 表示可用的持久化存储资源。Kubernetes 控制平面会根据 PVC 的需求来选择和绑定合适的 PV,将其挂载到应用程序的 Pod 中,从而使应用程序可…

Mock大法:Fake it till u make it!

在单元测试时,我们希望测试环境尽可能单纯、可控。因此我们不希望依赖于用户输入,不希望连接无法独占的数据库或者第三方微服务等。这时候,我们需要通 mock 来模拟出这些外部接口。mock 可能是单元测试中最核心的技术。 无论是 unittest 还是…

【DeepLearning-1】 注意力机制(Attention Mechanism)

1.1注意力机制的基本原理: 计算注意力权重: 注意力权重是通过计算输入数据中各个部分之间的相关性来得到的。这些权重表示在给定上下文下,数据的某个部分相对于其他部分的重要性。 加权求和: 使用这些注意力权重对输入数据进行加权…

Flink(十五)【Flink SQL Connector、savepoint、CateLog、Table API】

前言 今天一天争取搞完最后这一部分,学完赶紧把 Kafka 和 Flume 学完,就要开始做实时数仓了。据说是应届生得把实时数仓搞个 80%~90% 才能差不多找个工作,太牛马了。 1、常用 Connector 读写 之前我们已经用过了一些简单的内置连接器&#x…

用ChatGPT教学、科研!大学与OpenAI合作

亚利桑那州立大学(简称“ASU”)在官网宣布与OpenAI达成技术合作。从2024年2月份开始,为所有学生提供ChatGPT企业版访问权限,主要用于学习、课程作业和学术研究等。 为了帮助学生更好地学习ChatGPT和大语言模型产品,AS…

禅道的下载使用

文章目录 禅道的下载下载安装包 http://www.zentao.net/安装导南 禅道的使用创建用户产品经理将人员添加进禅道查看权限、产品经理使用禅道添加产品添加产品模块关联用例(测试主管)执行测试用例转bug 泳道图 禅道的下载 下载安装包 http://www.zentao.n…

电脑无法开机?重装系统教程在这!超详细

#电脑无法开机,怎么重装系统# 前言 本教程适合比较新的Windows电脑硬件。硬件的新旧并没有一个清晰的标准去判定,毕竟有些厂家生产的主板支持UEFI和Legacy两种引导方式,但部分厂家生产的硬件所使用的Bios并不支持Legacy,所以只能用UEFI引导来安装系统。 所以要使用哪种引…

容器原理之Union FS

一、前言 1.1 什么是 UnionFS 联合文件系统(UnionFS)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories in…

华为OD机试之阿里巴巴找黄金宝箱(IV) C++

题目背景 贫如洗的椎夫阿里巴巴在去砍柴的路上,无意中发现了强盗集团的藏宝地,藏宝地有编号从0-N的箱子,每个箱子上面有一人数字,箱子排列成一个环,编号最大的箱子的下一个是编号为0的箱子。请输出每个箱了贴的数字之…

【记一次线上事故的排查思路】- CPU飙升问题排查

问题描述 由于项目排期较紧,临时从其他组调来三个开发资源帮我一起做项目,难免上线的时候大家的需求一块上线。 问题来了,上线三天后,线上CPU总是莫名奇妙的突然飙升,飙升后CPU并未降下来,而是一直处在高点…

解密POM:提升自动化脚本稳定性和开发效率的正确姿势!

Page Objects是selenium的一种测试设计模式,主要将每个页面看作是一个class。class的内容主要包括属性和方法,属性不难理解,就是这个页面中的元素对象,比如输入用户名的输入框,输入登陆密码的输入框、登陆按钮、这个页…

《WebKit 技术内幕》学习之七(3): 渲染基础

3 渲染方式 3.1 绘图上下文(GraphicsContext) 上面介绍了WebKit的内部表示结构,RenderObject对象知道如何绘制自己,但是,问题是RenderObject对象用什么来绘制内容呢?在WebKit中,绘图操作被定…

【Leetcode】2765. 最长交替子数组

文章目录 题目思路代码结果 题目 2765. 最长交替子数组 题目:给你一个下标从 0 开始的整数数组 nums 。如果 nums 中长度为 m 的子数组 s 满足以下条件,我们称它是一个 交替子数组 : m 大于 1 。 s1 s0 1 。 下标从 0 开始的子数组 s 与…

Vue中$watch()方法和watch属性的区别

vue中$watch()和watch属性都是监听值的变化的,是同一个作用,但是有两个不同写法。 用法一: //注意:这种方法是监听不到对象的变化的。 this.$watch((newVal,oldVal)>{ }) 用法二: watch:{xxx:(newVal,oldVal)>…

SpringCloud Aliba-Seata【上】-从入门到学废【7】

目录 🧂.Seata是什么 🌭2.Seata术语表 🥓3.处理过程 🧈4.下载 🍿5.修改相关配置 🥞6.启动seata 1.Seata是什么 Seata是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能…

硅像素传感器文献调研(八)

1977 平面单场限环器件的理论与击穿电压 摘要 使用一个或多个浮置场限制环减少了平面器件中结曲率对击穿电压的不利影响。虽然这已经知道了一段时间,但还没有一种方法可以准确地预测使用场环可以实现的改善量。本文提出了一种计算机算法,它使得有可能进…

残差连接是什么意思

残差连接是深度神经网络中一种用于缓解梯度消失问题的技术。它的核心思想是通过将网络的输入直接传递到网络的输出,从而构建了一条直达路径,使得梯度更容易通过整个网络传播。这有助于在训练深层网络时避免梯度消失或梯度爆炸的问题。 在残差连接中&…

Linux 一键部署grafana

grafana 前言 Grafana 是一款开源的数据可视化和监控仪表盘工具。它提供了丰富的数据查询、可视化和报警功能,可用于实时监控、数据分析和故障排除等领域。 通过 Grafana,您可以连接到各种不同的数据源,包括时序数据库(如 Prometheus、InfluxDB)和关系型数据库(如 MySQ…

题记(26)--Sharing(链表公共后缀)

目录 一、题目内容 二、输入描述 三、输出描述 四、输入输出示例 五、完整C语言代码 一、题目内容 To store English words, one method is to use linked lists and store a word letter by letter. To save some space, we may let the words share the same sublist if…