WebDriverJS API说我可以写这样的代码:
driver.get("http://www.google.com");
driver.findElement(webdriver.By.name("q")).sendKeys("webdriver");
driver.findElement(webdriver.By.name("btnG")).click();
driver.getTitle().then(function(title) {
console.log(title);
//assertEquals("webdriver - Google Search", title);
});
这里的标题是“Google”。我可以修改代码:
driver.get("http://www.google.com");
driver.findElement(By.name("q")).sendKeys("webdriver");
driver.findElement(By.name("btnG")).click().then(function(){
/*WebDriverWait.until(function() {
driver.getTitle().then(function(title) {
console.log(title);
title = "webdriver - Google Search"
});
});*/
driver.sleep(3000).then(function() {
driver.getTitle().then(function(title) {
console.log(title);
});
});
});
现在标题是“webdriver - Google Search”。承诺在页面有机会加载之前更改状态。此示例来自API文档,因此它应该可以工作。
我看到了一个waiting on SO,的示例,但是我不知道将其转换为WebDriverJS中的工作代码,API没有提到“直到”。
答案 0 :(得分:0)
您可以在此处的源代码中查看如何使用wait
和until
:https://code.google.com/p/selenium/source/browse/javascript/webdriver/webdriver.js#653
var webdriver = require('selenium-webdriver');
var driver = new webdriver.Builder().
withCapabilities(webdriver.Capabilities.chrome()).
build();
driver.get('http://www.google.com');
driver.findElement(webdriver.By.name('q')).sendKeys('webdriver');
driver.findElement(webdriver.By.name('btnG')).click();
driver.wait(function() {
return driver.getTitle().then(function(title) {
console.log(title);
return title === 'webdriver - Google Search';
});
}, 1000).then(function() {
console.log('done!')
});
driver.quit();
给出输出:
webdriver - Google Search
done!