我一直在 nwjs/node.js 中开发一个浏览器自动化应用程序,它使用数据驱动的DSL指令。
我决定通过我的 package.json 中的以下依赖项为 chromedriver 和 selenium webdriver 使用 npm 包:
"dependencies": {
"selenium-webdriver": "~3.0.0-beta-2",
"chromedriver": "~2.23.1"
}
一切都很顺利,直到最近应用程序在启动 chromedriver 时停止工作:
var webdriver = require("selenium-webdriver");
var driver = new webdriver.Builder().forBrowser('chrome').build();
以下是在我的 Macbook 上终端运行时出现的错误:
/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/promise.js:654
throw error;
^
SessionNotCreatedError: session not created exception
from unknown error: Runtime.evaluate missing 'wasThrown'
(Session info: chrome=54.0.2840.71)
(Driver info: chromedriver=2.23.409710 (0c4084804897ac45b5ff65a690ec6583b97225c0),platform=Mac OS X 10.11.5 x86_64)
at WebDriverError (/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/error.js:27:5)
at SessionNotCreatedError (/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/error.js:214:5)
at Object.checkLegacyResponse (/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/error.js:505:15)
at parseHttpResponse (/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/http.js:396:13)
at doSend.then.response (/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/http.js:328:11)
at process._tickCallback (internal/process/next_tick.js:103:7)
From: Task: WebDriver.createSession()
at Function.createSession (/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/webdriver.js:366:24)
at Driver (/Users/matthewsanders/test1/node_modules/selenium-webdriver/chrome.js:804:38)
at Builder.build (/Users/matthewsanders/test1/node_modules/selenium-webdriver/index.js:546:16)
at Object.<anonymous> (/Users/matthewsanders/test1/index.js:4:59)
at Module._compile (module.js:556:32)
at Object.Module._extensions..js (module.js:565:10)
at Module.load (module.js:473:32)
at tryModuleLoad (module.js:432:12)
at Function.Module._load (module.js:424:3)
at Module.runMain (module.js:590:10)
From: Task: WebDriver.navigate().to(http://www.google.com)
at Driver.schedule (/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/webdriver.js:414:17)
at Navigation.to (/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/webdriver.js:1042:25)
at Driver.get (/Users/matthewsanders/test1/node_modules/selenium-webdriver/lib/webdriver.js:832:28)
at Object.<anonymous> (/Users/matthewsanders/test1/index.js:6:8)
at Module._compile (module.js:556:32)
at Object.Module._extensions..js (module.js:565:10)
at Module.load (module.js:473:32)
at tryModuleLoad (module.js:432:12)
at Function.Module._load (module.js:424:3)
at Module.runMain (module.js:590:10)
我还针对我当时制作的几个测试应用程序进行了测试,以确保这不是我在项目中引入的问题。
forBrowser
然后,我在下载geckodriver后尝试在该方法中使用“firefox”,效果很好。
看起来好像 chromedriver 的某种自动更新破坏了我的项目。我注意到有关 stackoverflow 的其他几个与类似错误相关的问题,尽管没有一个包含该Runtime.evaluate missing 'wasThrown'
错误,这似乎表明我的理论可能是正确的。
我可以继续切换到geckodriver,但我不确定我是否会遇到类似的问题。
我想这里真正的问题是......
如何禁用自动更新以保持此应用程序作为独立项目运行?
同样,这不是作为一个不断更新的测试套件,而是一个由自定义语言驱动的浏览器自动化应用程序。它既可以通过托管的 node.js 实例作为自动化解决方案运行,也可以作为使用 nwjs 运行的操作员驱动的 gui 应用程序运行。
编辑:
到目前为止,我已经找到了一个很有前途的方法。如果我让它按我的喜好工作,我会添加一个答案。
Selenium 文档包含有关如何自定义 chromedriver 选项的信息。我已经下载了一个Chromium版本并使用这个逻辑来连接它:
var chrome = require("selenium-webdriver/chrome");
var service = new chrome.ServiceBuilder().build();
var options = new chrome.Options();
options.setChromeBinaryPath("PATH/TO/MY/CHROMIUM");
var driver = new chrome.Driver(options, service);
注意:在 Mac 上,您必须提供应用程序包中实际可执行文件的路径,例如:“Chromium.app/Contents/MacOS/Chromium”。
到目前为止,我使用的是 Chromium 而不是 Chrome,版本仍然不正确,但我确实验证了它与我在没有设置路径的情况下运行的不同。从理论上讲,如果我能够可靠地冻结自动更新过程,同时仍然独立打包应用程序,我应该能够以相同的方式运行 Chrome。如果这不起作用,我可能会求助于使用 Chromium。