当 webdriverjs 从不调用延续,只是挂起时该怎么办

What to do when webdriverjs never calls a continuation, and just hangs?

本文关键字:挂起 怎么办 webdriverjs 调用 延续      更新时间:2023-09-26

我正在运行webdriverjs,并遇到了webdriver闲置并且似乎停止运行事件的问题。我正在使用 webdriver 启动一个新浏览器,然后该浏览器中的代码连接到 webdriver 会话并运行测试命令。

这似乎工作正常,但是对于一些命令序列,Web驱动程序只是停滞不前。例如,在我的测试中:

driver.findElement(my_element).then(function(element) {
  console.info("found");
  element.getTagName().then(function(name) {
    console.info("got tag name", name);
  });
});

浏览器输出第一个"找到"日志行,但不输出第二个"获取标签名称"。Webdriver 似乎没有失败 - 日志中没有异常,如果我在 getTagName 承诺上注册错误,它永远不会被调用。它只是没有发生。

Web驱动程序实例是一个Selenium独立服务器。查看其日志,我看到第一个findElement请求:

12:59:43.382 INFO - Executing: [execute script: return (function lookupElement(id) {
  var store = document["$webdriver$"];
  if(!store) {
    return null
  }
  var element = store[id];
  if(!element || element[id] !== id) {
    return[]
  }
  return[element]
}).apply(null, arguments);, [51d37tw]] at URL: /session/1337200865492/execute)
12:59:43.393 INFO - Done: /session/1337200865492/execute

但是我从未看到第二个请求,因此似乎webriver JS永远不会最终调用服务器。

我正在逐步浏览 webdriver 代码以查看发生了什么,但 promise 框架使用了很多闭包,并且很难有效地检查状态。有人熟悉这个问题吗?

这是WebdriverJS中的一个错误,由Selenium团队确认并修复。见 http://code.google.com/p/selenium/issues/detail?id=3930