簡體   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