您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

selenium-等待网络流量

selenium-等待网络流量

这就是我们最终要做的。(请注意,如果您始终仅使用单个框架(如JQuery),则有一种更简便的方法获取是否正在运行Ajax调用。我们不得不进行更多的jimmy- rig操作,因为我们有几个页面使用JQuery,使用GWT)

我创建了一个Javascript文件,只有在进行测试时,每个页面才会加载。(我是通过在JSP的模板中包含一个代码段来完成此操作的:如果将测试查询字符串参数作为true传递,则设置一个cookie。如果设置了cookie,则包括javascript文件)这个javascript文件实际上包装了XMLHttpRequest对象以保持计数所有发送请求中:

function wrapRequest(xmlRequest) {
    var oldSend = xmlRequest.prototype.send;
    xmlRequest.prototype.send = function() {
        var oldOnReady = this.onreadystatechange;
        oldOnReady = function() {
            oldOnReady.apply(this, arguments);
            // if call is complete, decrement counter.
        }
        // increment counter
        if(oldSend.apply)
            oldSend.apply(this, arguments);
        else if (oldOnReady.handleEvent) { //Firefox sometimes will need this
            oldOnReady.handleEvent.apply(this, arguments);
        }
    }
}

如果async == false,它还不止这些,但这应该很容易找出。

然后,我将一个函数添加到selenium user-extensions.js中,它看起来像这样:

Selenium.prototype.getIsNetworkReady = function() {
    if(this.browserbot.topWindow.isNetworkReady) { //sometimes this method is called before the page has loaded the isNetworkReady function
        return this.browserbot.topWindow.isNetworkReady();
    }
    return false;
}

另外,请注意对topWindow的检查:这是因为在选择iframe时遇到问题。

另外,您将必须在要加载的每个iFrame的XMLHttpRequest对象上调用wrapRequest方法。我现在使用:进行此操作document.addEventListener("DOMNodeInserted", onElementAdded, true);,然后在onElementAdded中,仅在iframe加载时抓取并传递XMLHttpRequest对象。但这在IE中不起作用,因此我正在寻找替代方法。如果有人知道有更好的方法可以在IE和FF中使用,那么我很想听听。

无论如何,这就是实现的要旨。希望这对将来的任何人有帮助。

其他 2022/1/1 18:14:09 有528人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶