无法使用Selenium和iewebriverserver 3.4.0在Windows Server 2016上针对IE


  • OS:Windows Server 2016数据中心(64位(
  • 浏览器:Internet Explorer 11.0.14393.0
  • 量角器:5.1.2
  • 硒服务器独立:3.4.0
  • iewebdriverserver.exe:3.4.0
  • java:1.8.0_131

我们正在尝试在Windows Server 2016 VM上针对Internet Explorer 11进行自动化测试。可以通过硒服务器对VM上的Chrome执行测试,但在IE中失败。

在反对IE时,量突击器可以启动IE打开的Selenium服务器。然后在地址栏中使用"大约:空白"启动另一个窗口。这很快就关闭了,以下错误显示在控制台窗口中:

[13:57:18] I/launcher - Running 1 instances of WebDriver  
[13:57:18] I/local - Starting selenium standalone server...  
[13:57:19] I/local - Selenium standalone server started at   http://10.X.X.X:61263/wd/hub   
Started    
A Jasmine spec timed out. Resetting the WebDriver Control Flow.    
Failures:  
1) angularjs homepage todo list should add a todo  
  Message:  
    Failed: JavaScript error (WARNING: The server did not provide any stacktrace information)  
    Command duration or timeout: 26 milliseconds  
    Build info: version: '3.4.0', revision: 'unknown', time: 'unknown'  
    System info: host: 'XXXX', ip: '10.X.X.X', os.name: 'Windows Server 2016',  os.arch: 'x86', os.version: '10.0', java.version: '1.8.0_131'  
    Driver info: org.openqa.selenium.ie.InternetExplorerDriver  

从Web驱动程序中进一步登录已发现了许多[访问被拒绝。]问题:

D 2017-06-22 10:43:26:213 BrowserFactory.cpp(248) Starting IE using the IELaunchURL API  
D 2017-06-22 10:43:26:360 BrowserFactory.cpp(202) IE launched successfully with process ID 4612  
D 2017-06-22 10:43:26:360 BrowserFactory.cpp(208) Process with ID 4612 is executing iexplore.exe  
D 2017-06-22 10:43:26:360 BrowserFactory.cpp(375) Using Active Accessibility to find IWebBrowser2 interface  
D 2017-06-22 10:43:27:615 BrowserFactory.cpp(434) Found window handle 000A017A for window with class 'Internet Explorer_Server' belonging to process with id 4612  
D 2017-06-22 10:43:27:636 BrowserFactory.cpp(396) Ignoring zoom setting: 0  
W 2017-06-22 10:43:27:644 BrowserFactory.cpp(664) -2147024891 [Access is denied.]: Call to IHTMLWindow2::get_screen failed  
…  
I 2017-06-22 10:43:28:028 Browser.cpp(130) No child frame focus. Focus is on top-level frame  
W 2017-06-22 10:43:28:040 Script.cpp(494) -2147024891 [Access is denied.]: Unable to execute code, call to IHTMLWindow2::execScript failed  
W 2017-06-22 10:43:28:040 Script.cpp(180) Cannot create anonymous function  
W 2017-06-22 10:43:28:040 response.cc(77) Error response has status code 17 and message 'JavaScript error' message  
…  

很明显,IE中存在许可问题,但是浏览器安全设置的放松量没有任何影响。

我尝试的是:

  1. 将"启用保护模式"设置为所有区域禁用
  2. 设置"允许Microsoft Web浏览器控件的脚本"启用
  3. 尝试了许多IEWEBDRIVERSERVERS,包括32位和64位版本
  4. 尝试IE11 32和64bit
  5. 为IE的32和64位实例添加了2个注册表键feature_bfcache(https://github.com/seleniumhq/seleniumhq/selenium/wiki/internetexplorerdriver(
  6. 禁用的"增强保护模式"
  7. 本文提到的配置:http://elgalu.github.io/2014/run-protractor-against-internet-explorer-vm/

有人成功地在Windows Server 2016上运行了Iedriverserver吗?我如何克服这些访问拒绝的问题?

量角配置:

exports.config = {
capabilities: {
'browserName': 'internet explorer',
'platform': 'WINDOWS',
'version': '11'
},
seleniumServerJar: '<absolute path to /npm/node_modules/protractor/node_modules/webdriver-manager/selenium/selenium-server-standalone-3.4.0.jar>',
localSeleniumStandaloneOpts : {
    jvmArgs : ["-Dwebdriver.ie.driver.loglevel=DEBUG", "-Dwebdriver.ie.driver.logfile=C:/IEServerlog.log", "-Dwebdriver.ie.driver=<absolute path to /npm/node_modules/protractor/node_modules/webdriver-manager/selenium/IEDriverServer3.4.0.exe>"]
},
specs: ['spec.js']
};

spec.js:

describe('angularjs homepage todo list', function() {
  it('should add a todo', function() {
    browser.get('https://angularjs.org');
    element(by.model('todoList.todoText')).sendKeys('write first protractor test');
    element(by.css('[value="add"]')).click();
    var todoList = element.all(by.repeater('todo in todoList.todos'));
    expect(todoList.count()).toEqual(3);
    expect(todoList.get(2).getText()).toEqual('write first protractor test');
    // You wrote your first test, cross it off the list
    todoList.get(2).element(by.css('input')).click();
    var completedAmount = element.all(by.css('.done-true'));
    expect(completedAmount.count()).toEqual(2);
  });
});

我在使用3.4.0

上解决了其他版本的webdriver-manager.got经历了这个问题。
webdriver-manager update --versions.standalone=3.4.0 --ie32 

将WebDriver-Manager更新为3.4.0,然后启动特定的3.4.0

webdriver-manager start --versions.standalone=3.4.0

您应该能够在IE浏览器中运行。

最新更新