【web系统UI自动化】关于UI自动化的总结
时间:2019-09-19
本文章向大家介绍【web系统UI自动化】关于UI自动化的总结,主要包括【web系统UI自动化】关于UI自动化的总结使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
实施过了web系统的UI自动化,回顾梳理下,想到什么写什么,随时补充。
首先,自动化测试不是手动测试的替代品,是比较好的补充,而且不是占大比重的补充。
70%的测试工作集中在底层接口测试和单元测试,20%的测试工作为集成测试,其他10%的测试即为界面测试。
开发方向:
- 尽可能的相通的模块,通用的封装
- 开发约定好,便于定位
- 适用兼容测试
- 无界面运行
- 快速定位问题:报错信息、错误截图
- 多环境
收益点
- 脚本开发时间和复用次数
- 快速验证,第一时间响应问题
还可以做哪些?
- 兼容性
- 多环境
- 便于快速定位
- 提炼更多通用模块。
- 调研更优解决方案,比如:cypress等
- case依赖优化
- 深度校验
什么样的项目适合web自动化
- 系统稳定,太多的阻止程序或更改。
- 准备之前,先手工测试,确认自动测试可以涵盖的系统功能。
- 需要多系统,多浏览器兼容性测试
什么样的功能点需要web自动化
- 主业务流程
- 易于实现自动化的web元素、页面
- 重复量大的功能
web自动化常见的验证点
- 页面元素验证
- 页面列表数据验证
- 页面元素属性?
- UI的文本,图片显示正确性
- UI的交互逻辑正确性测试
- UI上的用户行为正确性测试
对于web自动化框架常见的需求点
- 分布式执行,可以多机器,多浏览器同步执行脚本
- 适用于不同环境运行
- 分层设计,方便维护
- 生成测试报告
- 模块的复用
- 必要的日志搜集
UI自动化收益点的采集
- 回归测试需要定期运行,在自动化时,它们可以节省测试人员的时间,我们可以更专注于其他场景和探索性测试。
- 脚本开发时间和复用次数
- 误报频率
UI自动化缺点or局限
- 不能快速反馈(相对于单元测试和API测试)
- 只会对于case已确定的内容进行校验
- 运行的稳定性
- 发现的错误不多,大多数错误似乎是通过“意外”或进行探索性测试而发现的。这可能是因为在每个探索性测试会话期间,我们可能以不同的方式测试应用程序,从而通过应用程序找到新的漏洞。
- 编写优秀且稳定的XPath / CSS定位器所花费的时间,并在底层HTML标记发生变化时更新它们。
- UI本身的变化性,要想达到和手工测试相同的覆盖率,投入比较大。
如何进行CI(Continuous Integration),也就是持续集成
● 持续提交代码 (Check-in)
○ 一天之中多次提交
● 持续构建代码 (Build)
○ 保证在任何时刻代码是可以继续开发的
● 持续部署代码 (Deploy)
○ 保证始终有一个可以部署的版本
● 持续测试代码 (Test)
○ 每次提交均执行单元测试
○ 每天一次或数次集成测试
○ 每天一次或数次系统测试
不过,高频的集成,还是用接口更加合适,后面的工作会把系统的交互接口自动化,届时分享。
原文地址:https://www.cnblogs.com/pingguo-softwaretesting/p/10831034.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Godot游戏开发实践之四:搬运Unity的Pluggable AI教程
- TypeScript 4.1 新特性:字符串模板类型,Vuex 终于有救了?
- 使用 Node.js 定制你的技术雷达:上篇
- 使用 Node.js 定制你的技术雷达:中篇
- 大点干!早点散----------Redis从入门到精通!!!
- Python入门摘要
- 这些 ECMAScript 模块知识,都是我需要知道的
- 微信小程序【事件绑定】入门一篇就搞定
- 一个后端狗的 Vue 笔记【入门级】
- 这才是现代C++单例模式简单又安全的实现
- Linux 学习笔记(1) 查看文件内容
- Python从入门到熟练(3):第一个程序
- 数学系的概率论和我们的不太一样。。。
- 如何实现一个优雅的Python的Json序列化库
- 还在从零开始搭建项目?手撸了款快速开发脚手架!