答案可能是多种控制流程:
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(); }); }); });});
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)