向Selenium Webdriver网格发出并行请求

我试图使用selenium服务器网格并行运行多个命令。 这是我的第一个testing代码:

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 

请求的截图

“获取”按顺序立即出现,“driver.get”创build一个承诺。 我的想法是,这三个请求是asynchronous的,因此几乎同时出现。 但正如你在截图中看到的那样,它们将会一个接一个地被制作出来。 网格肯定有足够的selenium实例,为什么不是驱动程序并行工作? 在我看来,“新的webdriver.Builder()”创build了一种不工作的asynchronous单身,但等待先前的请求完成!

谢谢你的帮助!

答案可能是多个控制stream程 :

WebDriverJS支持使用webdriver.promise.createFlow()定义“并行”stream程。 这个函数接受一个将被传递新创build的stream的callback。 此stream程中计划的任务将彼此同步,但将保持独立于任何其他控制stream程。 每次调用createFlow()都会返回一个承诺,在stream程完成时parsing。

本章结尾处的示例(我将逐字)显示了多个Googlesearch条件正在被同时testing:

 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!'); }); 

应该很容易将自定义的驱动程序构build和查找添加到该示例中。 也许如下:

 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(); }); }); }); });