繁体   English   中英

Nightwatch.js无法循环运行浏览器

[英]Nightwatch.js not able to run browser in loop

我正在用一个守夜人编写一个测试,以读取json数据并使用json文件中的所有值集运行浏览器。

例如,我有一个json文件,其中包含多个用户的登录密码。 我想为json文件中提到的每个用户启动一个Web浏览器,并进行登录并关闭它。

我的json文件内容如下

{
"total_rows": 3,
"offset": 0,
"rows": [{
        "id": "1",
        "doc": {"username": "username1","password": "password1"}
    },{
        "id": "2",
        "doc": {"username": "username2","password": "password3"}
    },{
        "id": "3",
        "doc": {"username": "username3","password": "password3"}
    }]
}

下面是我的守夜人测试

var fs = require('fs');

module.exports = {

'read CSV contents' : function (browser) {
    var contents = fs.readFileSync("./config/testdata.json");
    var jsonContent = JSON.parse(contents);

    Object.keys(jsonContent.rows).forEach(element => {
        console.log('##########')
        console.log(jsonContent.rows[element].doc.password);
       browser
       .url('//some url')
       .useXpath()
       .setValue('//input[@id=\'username\']',jsonContent.rows[element].doc.username)
       .setValue('//input[@id=\'password\']',jsonContent.rows[element].doc.password)
       .pause(1000)
       .end()
        });
    }
}

上面的代码是在控制台上将所有三个密码打印在json文件中,然后仅启动浏览器一次。 我想启动浏览器并登录json文件中的每组密码。 我经历了几个论坛和教程,他们建议使用回调或Promise。 任何人都可以提出正确的做法吗? 如果您发布相同的示例代码,那将非常有帮助。

谢谢

首先,在单个测试运行夜视镜中运行end()之后,将认为测试立即完成,您将无法还原浏览器会话。

由于您要为每个用户名和密码打开和关闭浏览器-解决方案可能是在测试文件中定义多个测试运行功能。

但是,这需要一些技巧,但应该可以正常工作:

var fs = require('fs');

var contents = fs.readFileSync("./config/testdata.json");
var jsonContent = JSON.parse(contents);
var exports = {};

jsonContent.rows.forEach(element => {
  // Create a single test for each row passing "doc" object as the first parameter
  exports['Testing row #' + element.id] = runTest.bind(null, element.doc);
});

function runTest(doc, client) {
  client
    .url('//some url')
    // ... YOUR CODE GOES HERE
    .end();
}

module.exports = exports;

在这里,您基本上可以读取JSON文件,遍历其记录并为每个记录创建一个单独的测试运行函数,并使用bind()doc变量传递为第一个参数。

因此,对于守夜人,此测试应类似于:

module.exports = {
  'Testing row #1': function(client) {},
  'Testing row #2': function(client) {},
  'Testing row #3': function(client) {}
};

您唯一缺少的是将代码包装在browser.perform() 尽管我不是100%可以将.end()保留在perform 试试看,让我知道。

var fs = require('fs');

module.exports = {
  'read CSV contents' : function (browser) {
    var contents = fs.readFileSync("./config/testdata.json");
    var jsonContent = JSON.parse(contents);
    browser.perform(function(){
      Object.keys(jsonContent.rows).forEach(element => {
        console.log('##########')
          console.log(jsonContent.rows[element].doc.password);
          browser
            .url('//some url')
            .useXpath()
            .setValue('//input[@id=\'username\']',jsonContent.rows[element].doc.username)
            .setValue('//input[@id=\'password\']',jsonContent.rows[element].doc.password)
            .pause(1000)
            .end();
      });
    })
  }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM