分分钟玩转UI自动化测试

有没有那么一刻,看到自动模拟用户操作界面感觉好神奇。

timg.jpg

关于什么叫 UI 自动化测试就不解释了,基本上是你刚才脑海里想到什么就是什么。

在分层自动化测试中包括:UI 测试、集成/接口测试、单元测试。大神告诉我:UI 自动化测试在自动化测试中占比只有10%。先不用在乎具体这个比例是什么,我们关注的是实际价值,这个需要根据实际项目来判断。不过对于UI自动化,基本上做冒烟测试用例的自动化就差不多了,从 UI 上来验证主业务流程的稳定性,同时降低一些维护成本。

今天我们来聊聊WebdriverIO,WebdriverIO是Webdriver Node.js模块,API非常丰富,同时支持Mobile,不过说到Webdriver那就需要先了解一下Selenuim的发展过程,这里就不装逼了,有兴趣的可以到官方网站瞅瞅。

WebdriverIO 有两种使用模式,一种是 Standalone Mode,一种是 WDIO。官方其实是推荐使用 WDIO,大概几个原因:

  1. 调试方便

  2. 多模块并行测试

  3. 命令的执行都是同步的,直接通过变量接收结果,不用像Standalone Mode执行一个异步操作然后then...then...

  4. 提供配置文件,使测试参数的配置更简单

下面开始我们的项目:

项目搭建条件:
  1. 安装 JDK
  2. 安装 Node.js
  3. 安装 webdriverio
  4. 安装 selenium-standalone
  5. 安装 wdio
  6. 安装 mocha,测试框架
  7. 安装 chai,诊断库
目录结构:
测试项目目录结构.png
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,详细说明戳这里: selenium-standalone,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, /已经成为好友|成功加入|已经申请|成功申请/, '判断收到的消息是否包含指定的内容');
});
执行测试:

控制台A

npm run selenium  //启动selenium-server

控制台B

npm run test //执行test
生成测试报告:
npm run allure
某次测试结果.png
总结:
  1. WebdriverIO 的命令上面提到的只是很小一部分,有兴趣赶快玩起来;

  2. describe、it 都是 Mocha 内提供的方法,单条用例的调试可以使用 it.only,单个 describe 可以 describe.only,关于 Mocha 介绍戳这里 Mocha

  3. Chai 提供 BDD(行为驱动开发) 断言风格和 TDD(测试驱动开发) 断言风格,关于 Chai 介绍戳这里 Chai

  4. 有时候不用非要断言来验证用例是否正确执行,像上面的登录的用例中,waitForExist 的元素是登录成功后才可以看见,所以这样也是可以代表成功的;

参考链接:
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容