Promise 执行得太早

Promise executes too early

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 没有提及 "until".

您可以在此处的源代码中查看如何使用 waituntilhttps://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!