向Selenium Webdriver网格发出并行请求

向Selenium Webdriver网格发出并行请求,第1张

向Selenium Webdriver网格发出并行请求

答案可能是多种控制流程

WebDriverJS 支持使用定义“并行”流

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 depredImage = new Buffer(data, 'base64') driver.quit();        });    }); });});


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/4903900.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-12
下一篇 2022-11-12

发表评论

登录后才能评论

评论列表(0条)

保存