我正在尝试使用selenium服务器网格并行运行多个命令。 这是我的第一个测试代码:
var webdriver = require('selenium-webdriver');
for(var u = 0; u < 3; u++) {
makeScreenshot('foo/test' + u + '.png');
}
function makeScreenshot(path) {
var driver = new webdriver.Builder().forBrowser('firefox').usingServer('http://someurl:44111/wd/hub/').build();
console.log('Get');
driver.get('http://www.somepage.com').then(function() {
console.log('Screenshot');
driver.takeScreenshot().then(function(data){
console.log(path);
//var decodedImage = new Buffer(data, 'base64')
driver.quit();
});
});
}
结果就是这样:
Get
Get
Get
Screenshot
foo/test0.png
Screenshot
foo/test1.png
Screenshot
foo/test2.png
“Get”会立即显示,“driver.get”会创建一个承诺。我的想法是这三个请求是异步进行的,因此几乎同时出现。但正如您在屏幕截图中看到的那样,它们将一个接一个地制作。 网格肯定有足够的selenium实例,为什么驱动程序不能并行工作? 在我看来,“new webdriver.Builder()”会创建一些不同步的单例,但是等待先前的请求完成!?
感谢您的帮助!
答案 0 :(得分:4)
答案可能是multiple control flows:
WebDriverJS 支持定义&#34; parallel&#34;流动使用
webdriver.promise.createFlow()
。此函数接受回调 将传递新创建的流程。在此内安排的任务 流程将彼此同步,但将保持独立 任何其他控制流程。每次调用createFlow()都会返回一个 承诺将在流程完成时解决。
本章末尾的示例(我非常逐字逐句地)显示了同时测试的多个Google搜索字词:
var terms = [
'javascript',
'selenium',
'webdriver'
];
var flows = terms.map(function(term) {
return webdriver.promise.createFlow(function() {
var driver = new webdriver.Builder().build();
driver.get('http://www.google.com');
driver.findElement(webdriver.By.name('q')).sendKeys(term);
driver.findElement(webdriver.By.name('btnG')).click();
driver.getTitle().then(function(title) {
if (title !== (term + ' - Google Search')) {
throw Error('Unexpected title: ' + title);
}
});
});
});
webdriver.promise.fullyResolved(flows).then(function() {
console.log('All tests passed!');
});
将自定义驱动程序构建和查找添加到该示例中应该很容易。也许如下:
var flows = [0,1,2,3].map(function(index) {
return webdriver.promise.createFlow(function() {
var driver = new webdriver.Builder().forBrowser('firefox').usingServer('http://someurl:44111/wd/hub/').build();
console.log('Get');
driver.get('http://www.somepage.com').then(function() {
console.log('Screenshot');
driver.takeScreenshot().then(function(data){
console.log('foo/test' + index + '.png');
//var decodedImage = new Buffer(data, 'base64')
driver.quit();
});
});
});
});