我正在尝试在一些远程自动化服务(Sauce Labs、Browserstack 等)上运行 Selenium 测试,并在通过我的公司防火墙访问它们的 API 时遇到问题。
请注意,我要测试的应用程序不在这个防火墙之后,它是可公开访问的。
DesiredCapabilities caps = DesiredCapabilities.internetExplorer();
caps.setCapability("platform", "Windows 7");
caps.setCapability("version", "9.0");
caps.setCapability("idleTimeout", "300");
caps.setCapability("name", "Invitation Tests");
driver = new RemoteWebDriver(new URL("https://user:key@saucelabs.com), caps);
问题似乎是 Selenium 的管道将 url 中的 user:key 解释为代理凭据,因此它永远不会离开我们的网络。配置这个有什么具体的技巧吗?它似乎在后台使用 Apache HttpClient。
我认为我们正在使用 NTLM 代理,它似乎使用基本身份验证。从这里可能是同一个问题:https://code.google.com/p/selenium/issues/detail?id=7286
最佳答案
您链接到的 Google 代码问题似乎确实是原因。请注意,该问题已得到解决,因此您现在可以在创建 RemoteWebDriver 时注入(inject)您自己的 CommandExecutor 实现。
具体来说,您可能会这样做:
- 编写
org.openqa.selenium.remote.http.HttpClient.Factory
的自定义实现,其行为与 https://github.com/SeleniumHQ/selenium/blob/master/java/client/src/org/openqa/selenium/remote/internal/ApacheHttpClient.java 中的类似,但允许您注入(inject)HttpClient
实例(或HttpClientFactory
实例,如果您想对其进行子类化)。这是一个非常简单的界面和一个易于复制的实现,因此这应该很容易。 - 创建一个
org.apache.http.impl.client.BasicCredentialsProvider
的实例,为不同的主机使用不同的凭据(参见org.apache.http.auth.AuthScope
详情)。 - 使用
org.apache.http.impl.HttpClientBuilder
使用您的凭据提供程序构建客户端。 - 构造一个
HttpCommandExecutor
的实例,传入您的自定义工厂实例并注入(inject)您的客户端。 - 构造
RemoteWebDriver
实例,传入命令执行器。
关于java - 在企业代理后面使用 Selenium RemoteWebDriver (Java),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33263006/