等到条件满足Selenium-Webdriver

时间:2016-03-02 14:18:40

标签: javascript node.js selenium-webdriver

我正在尝试在selenium-webdriver条件之上创建其他条件。我仍在努力掌握承诺和回调的完整概念。由于堆栈溢出的帮助,我得到了极大的改进。我不确定如何在javascript中每隔这么多秒重复一个条件。我的遗产也可能是错的。

var WebElementCondition = require('./selenium-webdriver/lib/until');

var ExpectedConditions = function()
{
    this.waitForWindowWithTitle = function (title)
    {

        return driver.getAllWindowHandles().then(function (title, handles) {

            console.log(handles.length + ' .then function');

            for (var window in handles) {
                if (window.title === title) 
                {
                    return true;
                }
                else 
                {
                    return false;
                }
            }
        });

    }
}

module.exports = ExpectedConditions;
require('util').inherits(module.exports, WebElementCondition);

在waitForWindowWithTitle函数中,我会做类似

的操作
return driver.wait(10000).then(function() {
     driver.getAllWindowHandles().then(function (title, handles) {

        console.log(handles.length + ' .then function');

        for (var window in handles) {
            if (window.title === title)
            {
                return true;
            }
            else
            {
                return false;
            }
        }
    });
});

1 个答案:

答案 0 :(得分:0)

您可以使用wait接受任何JS函数来创建自定义条件。这是一个检查角度准备就绪的示例。

// Wait for Angular to Finish
function angularReady(): any  {
  return $browser.executeScript("return (window.angular !== undefined) && (angular.element(document).injector() !== undefined) && (angular.element(document).injector().get('$http').pendingRequests.length === 0)")
     .then(function(angularIsReady) {                        
                    return angularIsReady === true;
                  });
}

$browser.wait(angularReady, 5000).then(...);

等待类型定义

wait<T>(condition: promise.Promise<T> | until.Condition<T> | ((driver: WebDriver) => T) | Function, timeout?: number, opt_message?: string): promise.Promise<T>;