我正在尝试使用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
请求的屏幕截图
“获取”立即按顺序显示,“ driver.get”创建一个承诺。我的想法是,这三个请求是异步发出的,因此几乎同时出现。但正如您在屏幕截图中看到的那样,它们将一个接一个地制成。网格肯定有足够的selenium实例,那么为什么驱动程序不能并行工作?在我看来,“ new webdriver.Builder()”会创建某种无法正常工作但等待上一个请求完成的单例!
谢谢你的帮助!
答案可能是多种控制流程:
WebDriverJS 支持使用定义“并行”流 webdriver.promise.createFlow()。该函数接受一个回调,该回调将传递给新创建的流。在此流中计划的任务将彼此同步,但将保持独立于任何其他控制流。每次对createFlow()的调用都会返回一个承诺,该承诺将在流程完成后解决。
webdriver.promise.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(); }); }); }); });