zoukankan      html  css  js  c++  java
  • Nightmare基于phantomjs的自动化测试套件

    今天将介绍一款自动化测试套件名叫nightmare,他是一个基于phantomjs的测试框架,一个基于phantomjs之上为测试应用封装的一套high level API。其API以goto, refresh, click, type…等简单的常用e2e测试动作封装,使得其语义清晰,简洁。其官方在http://www.nightmarejs.org/.

    如果你的项目测试不需要想需求和测试人员理解,那么基于nightmare测试或许是一个好的选择,你的降低测试代码的成本,以及测试套件的部署。我们可以选择基于jasmine-node等作为测试套件集成。

    安装nightmare:

    npm install nightmare
    

    下面我们对比与远程phantomjs的对比:

    原phantomjs的代码:

    phantom.create(function (ph) {
      ph.createPage(function (page) {
        page.open('http://yahoo.com', function (status) {
          page.evaluate(function () {
            var el =
              document.querySelector('input[title="Search"]');
            el.value = 'github nightmare';
          }, function (result) {
            page.evaluate(function () {
              var el = document.querySelector('.searchsubmit');
              var event = document.createEvent('MouseEvent');
              event.initEvent('click', true, false);
              el.dispatchEvent(event);
            }, function (result) {
              ph.exit();
            });
          });
        });
      });
    });
    

    nightmare代码:

    new Nightmare()
      .goto('http://yahoo.com')
      .type('input[title="Search"]', 'github nightmare')
      .click('.searchsubmit')
      .run();
    

    一切显而易见,不用多说。

    nightmare同时也支持插件方式抽取公用逻辑,以供复用和提高测试代码语意,如下例子:

    /**
     * Login to a Swiftly account.
     *
     * @param {String} email
     * @param {String} password
     */
    
    exports.login = function(email, password){
      return function(nightmare) {
        nightmare
          .viewport(800, 1600)
          .goto('https://swiftly.com/login')
            .type('#username', email)
            .type('#password', password)
            .click('.button--primary')
          .wait();
      };
    };
    

    使用代码很简单:

    var Swiftly = require('nightmare-swiftly');
    new Nightmare()
      .use(Swiftly.login(email, password))
      .use(Swiftly.task(instructions, uploads, path))
      .run();
    
  • 相关阅读:
    ThinkPHP中pathinfo模式与URL重写
    JS分割字符串并放入数组的函数
    js解决弹窗问题实现班级跳转DIV示例
    javascript客户端遍历控件与获取父容器对象
    Apache 虚拟目录和默认首页的设置
    linux Apache CGI 安装配置
    apache与和mysql重启命令
    带你从零学ReactNative开发跨平台App开发(三)
    带你从零学ReactNative开发跨平台App开发(一)
    C#/Net定时导出Excel并定时发送到邮箱
  • 原文地址:https://www.cnblogs.com/whitewolf/p/4111312.html
Copyright © 2011-2022 走看看