UI 自动化测试: UIRecorder + Selenium standalone server 搭建 Web UI 自动化测试
相关文档链接:
1. 操作: https://www.jianshu.com/p/f7b11da864fa
官方网站:http://uirecorder.com/
Github:https://github.com/alibaba/uirecorder
使用手册:https://github.com/alibaba/uirecorder/blob/master/doc/zh-cn/readme.md
安装
1. 安装 Java JDK 并配置环境变量
2. 安装 nodejs
注意,目前Nodejs官网上发布的最新版本为v10.14.2,但是使用最新版本的Nodejs时,UI Recorder在初始化时会有问题(在Start Install project dependencies步骤卡住)
可用版本下载链接: https://nodejs.org/dist/v8.11.3/node-v8.11.3-x64.msi
3. 安装 chrome 浏览器
4. 安装 UIRecorder
使用管理员权限 在 cmd 窗口:
npm install -g cnpm --registry=https://registry.npm.taobao.org cnpm install uirecorder mocha -g
5. 检查浏览器与driver版本是否对应
1)selenium之 chromedriver与chrome版本映射表(https://blog.csdn.net/huilan_same/article/details/51896672)
2) C:\Users\{username}\AppData\Roaming\npm\node_modules\uirecorder\package.json
将chromedriver 改成 浏览器对应的 driver 版本,如本机安装的chrome 为 72.0,则对应的 driver 为 2.45.0
3)
cd C:\Users\xxxxx\AppData\Roaming\npm\node_modules\uirecorder cnpm install // 更新uirecorder依赖的chromedriver为2.40.0版本 npm ls chromedriver -g // 查看chromedriver的版本
开始录制
1. 初始化工程
E: mkdir project_name // 创建工作目录 cd project_name // 进入到工作目录中,以下的命令都是在此工作目录中执行 uirecorder init // 初始化uirecorder
* 一路回车,浏览器的地方选择 "Chrome"
2. 开始录制测试用例
启动uirecorder录制,并且录制的脚本保存到工作目录下的sample/test.spec.js
uirecorder start
此时会打开两个chrome浏览器,一个用来校验的,一个用来录制脚本的
回放
1. 安装并启动 selenium-standalone
cnpm install selenium-standalone@latest -g selenium-standalone install // 运行这个需要java selenium-standalone start
2. 运行回放
run.bat sample/test.spec.js
查看回测报告
reports\index.html
原文地址:https://www.cnblogs.com/bruce-he/p/11720066.html
- HashSet
- 树莓派的GPIO编程
- Java集合源码分析(三)Vevtor和Stack
- JS魔法堂:再识instanceof
- Web开发之CSS
- Linux重启命令与如何重启网络?
- spring boot + embed tomcat + standalone jar的内存泄露问题
- 树莓派:设置与软件安装
- spring-boot 速成(11) - 单元测试
- OOAD-设计模式(四)结构型模式之适配器、装饰器、代理模式
- 2018年智能家居行业趋势 写在2017年关键词里
- 树莓派与arduino通信
- process information unavailable 的解决办法
- JS魔法堂:再识IE的内存泄露
- 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 数组属性和方法
- bean无法注入(与文件包位置有关)及修改包项目、model名
- Jackson第一篇
- jackson第二篇
- 从源码分析常见集合的区别之List接口
- c++ 调用ffmpeg命令获取视频属性
- Kubernetes 1.19.0——网络策略
- TypeScript 参数简化实战(进阶知识点conditional types,中高级必会)
- 最简实现Promise,支持异步链式调用(20行)
- 40行代码把Vue3的响应式集成进React做状态管理
- 写给女朋友的中级前端面试秘籍(含详细答案,15k级别)
- 写给初中级前端的高级进阶指南
- 为什么 Vue 中不要用 index 作为 key?(diff 算法详解)
- Vue3 的响应式和以前有什么区别,Proxy 无敌?
- 腾讯云TKE-PV使用cos存储案例: 容器目录权限问题
- Vue3 究竟好在哪里?(和 React Hook 的详细对比)