分分钟玩转UI自动化测试
有没有那么一刻,看到自动模拟用户操作界面感觉好神奇。

关于什么叫 UI 自动化测试就不解释了,基本上是你刚才脑海里想到什么就是什么。
在分层自动化测试中包括:UI 测试、集成/接口测试、单元测试。大神告诉我:UI 自动化测试在自动化测试中占比只有10%。先不用在乎具体这个比例是什么,我们关注的是实际价值,这个需要根据实际项目来判断。不过对于 UI 自动化,基本上做冒烟测试用例的自动化就差不多了,从 UI 上来验证主业务流程的稳定性,同时降低一些维护成本。
今天我们来聊聊 WebdriverIO,WebdriverIO 是 Webdriver Node.js 模块,API 非常丰富,同时支持 Mobile,不过说到 Webdriver 那就需要先了解一下 Selenuim 的发展过程,这里就不装逼了,有兴趣的可以到官方网站瞅瞅。
WebdriverIO 有两种使用模式,一种是 Standalone Mode,一种是 WDIO。官方其实是推荐使用 WDIO,大概几个原因:
调试方便
多模块并行测试
命令的执行都是同步的,直接通过变量接收结果,不用像 Standalone Mode 执行一个异步操作
提供配置文件,使测试参数的配置更简单
下面开始我们的项目:
项目搭建条件:
- 安装 JDK
- 安装 Node.js
- 安装 webdriverio
- 安装 selenium-standalone
- 安装 wdio
- 安装 mocha,测试框架
- 安装 chai,诊断库
目录结构:

package.json:
"devDependencies": {
"webdriverio": "^4.6.2", // webdriverio 库
"selenium-standalone": "^6.2.0", // selenium standalone server、浏览器driver安装
"wdio": "^0.3.3", // wdio测试运行器
"wdio-mocha-framework": "^0.5.9", // 摩卡测试框架
"chai": "^3.5.0", // 诊断库
"wdio-spec-reporter": "^0.1.0", // 控制台输出测试报告
"allure-commandline": "^1.5.0", // 根据测试结果生成测试报告
"wdio-allure-reporter": "^0.1.2" // 根据测试报告展现更直观的UI界面
},
"scripts": {
"selenium": "selenium-standalone start", // 启动selenium
"test": ".\\node_modules\\.bin\\wdio", // 执行test
"allure": "allure generate allure-results && allure report open" //生成测试报告
}
关于 wdio-spec-reporter、allure-commandline、wdio-allure-reporter 不一定全需要安装。
selenium-standalone 包安装成功后需要执行以下命令来安装各浏览器 driver,install的过程中可能会遇到问题,建议翻墙试试
selenium-standalone install
安装成功后,执行以下命令就可以启动 selenium-server:
selenium-standalone start
wdio 配置文件:
var config = require('./config');
var common = require('./common');
exports.config = {
// selenium-server 启动的IP和端口,默认是4444
host: '127.0.0.1',
port: 4444,
// 哪些文件执行测试
specs: [
'./modules/*.js'
],
// 哪些文件不执行测试
exclude: [
'./modules/function.js',
'./modules/register.js',
'./modules/invite.js'
],
// 使用什么浏览器来执行测试
capabilities: [{
browserName: 'chrome',
maxInstances: 1, // 最多启动多少个浏览器窗口并行执行
chromeOptions: {
args: ['disable-extensions']
}
}],
logLevel: 'silent',
coloredLogs: true,
baseUrl: config.webUrl,
waitforTimeout: 100000, // 100s
framework: 'mocha',
reporters: ['spec', 'allure'], // 两种测试报告方式
reporterOptions: {
allure: {
outputDir: 'allure-results' // allure测试结果上传目录
}
},
mochaOpts: {
ui: 'bdd',
timeout: 99999999 // 整个测试执行的超时时间,长就对了
},
// 每次执行测试前把之前allure保留的测试结果清空
onPrepare: function (config, capabilities) {
common.deleteFile('./allure-report');
common.deleteFile('./allure-results');
}
};
登录测试用例:
describe('login-test', function () {
it('login', function () {
return browser
.deleteCookie() // 删除所有cookie
.url(config.webUrl + '/login.htm') // 打开登录页面
.setValue('#txtMobilePhone', config.loginInfo.mobilePhone) // 设置手机号
.setValue('#txtPassword', config.loginInfo.password) // 设置密码
.click('#btnLogin') // 点击登录按钮
.waitForExist('#topBarContent', config.waitMS); // 如果这样元素存在代表成功
});
});
方法注册与调用说明:
// 可以通过 browser.checkInviteSuccess()调用
browser.addCommand('checkInviteSuccess', function (inboxType) { $('.sessionList .sessionItem[id="' + inboxType + '"]').click();
browser.waitForExist('.messageItem', config.waitMS); var result = browser
.execute(function () {
var text = null;
$('.inboxBox .messageItem .textMsg').each(function () {
text += $(this).text();
});
return text;
}); // 断言正则表达式方法
assert.match(result.value, /已经成为好友|成功加入|已经申请|成功申请/, '判断收到的消息是否包含指定的内容');
});
如果对软件测试、接口测试、自动化测试、面试经验交流。感兴趣可以加软件测试交流:1085991341,还会有同行一起技术交流。
执行测试:
控制台A
npm run selenium //启动selenium-server
控制台B
npm run test //执行test
生成测试报告:
npm run allure

总结:
有时候不用非要断言来验证用例是否正确执行,像上面的登录的用例中,waitForExist 的元素是登录成功后才可以看见,所以这样也是可以代表成功的。
以上就是本文的全部内容,希望对大家的学习有所帮助。有被帮助到的朋友欢迎点赞,评论。
分分钟玩转UI自动化测试的更多相关文章
- 腾讯优测优分享 | 游戏的UI自动化测试可以这样开展
腾讯优测是专业的自动化测试平台,提供自动化测试-全面兼容性测试,云真机-远程真机租用,漏洞分析等多维度的测试服务,让测试更简单! 对于目前的两大游戏引擎cocos-2dx.unity3D,其UI自动化 ...
- 使用WatiN进行UI自动化测试
Watin是一个UI自动化测试工具,支持ie/firefox,官方网站:http://watin.org/. 主要有以下特点: 支持主要的html元素,见:http://watin.org/docum ...
- 如何正确选择UI自动化测试
近年流行一个词-UI,和UI搭边好像都那么高大上,软件测试行业也不例外,比如UI自动化测试. 常见的UI自动化测试程序有哪些呢? l 带UI的Unit Test,比如mock掉底层代码,仅仅测试UI ...
- UI自动化测试框架(项目实战)python、Selenium(日志、邮件、pageobject)
其实百度UI自动化测试框架,会出来很多相关的信息,不过就没有找到纯项目的,无法拿来使用的:所以我最近就写了一个简单,不过可以拿来在真正项目中可以使用的测试框架. 项目的地址:https://githu ...
- 【转】Web UI自动化测试原理
目前市面上有很多Web UI自动化测试框架,比如WatiN, Selinimu,WebDriver,还有VS2010中的Coded UI等等. 这些框架都可以操作Web中的控件,模拟用户输入,点击等 ...
- 关于去哪儿网的UI自动化测试脚本(Python实现)
UI自动化测试Qunar机票搜索场景访问Qunar机票首页http://flight.qunar.com,选择“单程”,输入出发.到达城市,选择today+7日后的日期,点“搜索”,跳转到机票单程搜索 ...
- 也来“玩”Metro UI之磁贴
也来“玩”Metro UI之磁贴 Win8出来已有一段时间了,个人是比较喜欢Metro UI的.一直以来想用Metro UI来做个自己的博客,只是都没有空闲~~今天心血来潮,突然想自己弄一个磁贴玩玩, ...
- UI自动化测试(三)对页面中定位到的元素对象做相应操作
前两天分别讲述了UI自动化测试基础以及对页面元素该如何进行定位,这一篇自然就是对定位到的页面元素对象进行相应操作啦. 阅读目录 1.常用操作元素对象的方法 2.鼠标事件操作 3.键盘事件操作 4.We ...
- Selenide UI 自动化测试
我没有拼写错误,确实不是 Selenium ,但是,只要是 Web UI 自动化测试框架,基本上都是基于Selenium 的.Selenide 也不例外.那为啥不直接用Selenium呢? 因为 ...
随机推荐
- Blob分析之board.hdev
* board.hdev: Detection of missing solder* 获取当前系统参数get_system ('clip_region', Information)*设置当前系统参数s ...
- 牛客IOI周赛17-提高组 卷积 生成函数 多项式求逆 数列通项公式
LINK:卷积 思考的时候 非常的片面 导致这道题没有推出来. 虽然想到了设生成函数 G(x)表示最后的答案的普通型生成函数 不过忘了化简 GG. 容易推出 \(G(x)=\frac{F(x)}{1- ...
- 5.15 省选模拟赛 T1 点分治 FFT
LINK:5.15 T1 对于60分的暴力 都很水 就不一一赘述了. 由于是询问所有点的这种信息 确实不太会. 想了一下 如果只是询问子树内的话 dsu on tree还是可以做的. 可以自己思考一下 ...
- 4.13 省选模拟赛 树 树形dp 卷积 NTT优化dp.
考试的时候 看到概率 看到期望我就怂 推了一波矩阵树推自闭了 发现 边权点权的什么也不是. 想到了树形dp 维护所有边的断开情况 然后发现数联通块的和再k次方过于困难. 这个时候 应该仔细观察一下 和 ...
- 剑指 Offer 58 - II. 左旋转字符串
本题 题目链接 题目描述 我的题解 方法一:使用库函数 s.substring() 代码如下 public String reverseLeftWords(String s, int n) { ret ...
- 【原创】xenomai与VxWorks实时性对比(Jitter对比)
版权声明:本文为本文为博主原创文章,转载请注明出处.如有问题,欢迎指正.博客地址:https://www.cnblogs.com/wsg1100/ (下面数据,仅供个人参考) 可能大部分人一直好奇Vx ...
- 基于asp.net core 从零搭建自己的业务框架(一)
前言 asp.net core版本选择2.2,只是因为个人习惯了vs2017,代码以及设计皆可移植到vs2019,用asp.net core 3.0以及以上运行起来 项目类似选择web api,基础设 ...
- cxuan读者的外包面试之旅
最开始是打算面试外包公司刷经验,等经验差不多了,再去甲方尝试,可惜不太顺利. 一.迈思(面试了30分钟) 自我介绍 左连接(a 表左连接 b 表,a 表全部数据出来,b 表没有的数据为空) a 表左连 ...
- JavaScript中为什么需要!!?
1. 布尔值为false的值 在JavaScript中,布尔值为 false的值有如下几个: undefined null false 0 NaN ""或''(空字符串) 2. ! ...
- axios的post请求返回状态码400
设置拦截 axios.interceptors.request.use((config) => { if (config.method === 'post') { if (!config.isF ...