com.googlecode.jmeter.plugins.webdriver.config.InternetExplorerDriverConfig Maven / Gradle / Ivy
The newest version!
package com.googlecode.jmeter.plugins.webdriver.config;
import java.io.File;
import java.io.IOException;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import org.openqa.selenium.ie.InternetExplorerDriver;
import org.openqa.selenium.ie.InternetExplorerDriverService;
import org.openqa.selenium.ie.InternetExplorerOptions;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class InternetExplorerDriverConfig extends WebDriverConfig {
private static final long serialVersionUID = 100L;
private static final Logger LOGGER = LoggerFactory.getLogger(InternetExplorerDriverConfig.class);
private static final Map services = new ConcurrentHashMap();
Map getServices() {
return services;
}
@Override
protected InternetExplorerDriver createBrowser() {
final InternetExplorerDriverService service = getThreadService();
InternetExplorerOptions ieOptions = createIEOptions();
return service != null ? new InternetExplorerDriver(service, ieOptions) : null;
}
@Override
public void quitBrowser(final InternetExplorerDriver browser) {
super.quitBrowser(browser);
final InternetExplorerDriverService service = services.remove(currentThreadName());
if (service != null && service.isRunning()) {
service.stop();
}
}
private InternetExplorerDriverService getThreadService() {
InternetExplorerDriverService service = services.get(currentThreadName());
if (service != null) {
return service;
}
try {
/*
* For debugging purposes
* System.setProperty("webdriver.ie.driver.loglevel", "DEBUG");
* System.setProperty("webdriver.ie.driver.logfile", "C:\\DEV\\WebDriverIeDriver.log");
*/
service = new InternetExplorerDriverService.Builder().usingDriverExecutable(new File(getDriverPath())).build();
service.start();
services.put(currentThreadName(), service);
} catch (IOException e) {
LOGGER.error("Failed to start IE service");
service = null;
}
return service;
}
}