[英]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.