美文网首页软件测试
玩转UI自动化测试

玩转UI自动化测试

作者: 梵音11 | 来源:发表于2020-06-27 21:22 被阅读0次

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

关于什么叫 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

总结:

1.WebdriverIO 的命令上面提到的只是很小一部分,有兴趣赶快玩起来

2.describe、it 都是 Mocha 内提供的方法,单条用例的调试可以使用 it.only,单个 describe 可以 describe.only

3.Chai 提供 BDD(行为驱动开发) 断言风格和 TDD(测试驱动开发) 断言风格

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

如果对软件测试、接口测试、自动化测试、面试经验交流。感兴趣可以加软件测试交流群:829792258,还会有同行一起技术交流。

相关文章

网友评论

    本文标题:玩转UI自动化测试

    本文链接:https://www.haomeiwen.com/subject/tlavfktx.html