nl.hsac.fitnesse.fixture.slim.web.SeleniumDriverSetup Maven / Gradle / Ivy
package nl.hsac.fitnesse.fixture.slim.web;
import nl.hsac.fitnesse.fixture.Environment;
import nl.hsac.fitnesse.fixture.slim.SlimFixture;
import nl.hsac.fitnesse.fixture.util.selenium.SauceLabsHelper;
import nl.hsac.fitnesse.fixture.util.selenium.SeleniumHelper;
import nl.hsac.fitnesse.fixture.util.selenium.driverfactory.DriverFactory;
import nl.hsac.fitnesse.fixture.util.selenium.driverfactory.DriverManager;
import nl.hsac.fitnesse.fixture.util.selenium.driverfactory.LocalDriverFactory;
import nl.hsac.fitnesse.fixture.util.selenium.driverfactory.ProjectDriverFactoryFactory;
import nl.hsac.fitnesse.fixture.util.selenium.driverfactory.RemoteDriverFactory;
import org.openqa.selenium.Capabilities;
import org.openqa.selenium.Platform;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxOptions;
import org.openqa.selenium.firefox.FirefoxProfile;
import org.openqa.selenium.remote.DesiredCapabilities;
import org.openqa.selenium.remote.RemoteWebDriver;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.function.BiFunction;
import static nl.hsac.fitnesse.fixture.util.selenium.driverfactory.LocalDriverFactory.getFirefoxProfile;
import static nl.hsac.fitnesse.fixture.util.selenium.driverfactory.RemoteDriverFactory.REMOTE_URL_KEY;
/**
* Script fixture to set up webdriver to be used by Selenium tests.
*/
public class SeleniumDriverSetup extends SlimFixture {
private static final String LAST_RUN_SUMMARY = "SeleniumLastRunSummary";
protected static boolean OVERRIDE_ACTIVE = false;
private final List secretCapabilities = new ArrayList<>();
/**
* Sets system property (needed by the WebDriver to be set up).
*
* @param propName name of property to set.
* @param value value to set.
* @return true.
*/
public boolean setPropertyValue(String propName, String value) {
if (OVERRIDE_ACTIVE) {
return true;
}
System.setProperty(propName, value);
return true;
}
/**
* Creates an instance of the specified class an injects it into SeleniumHelper, so other fixtures can use it.
*
* @param driverClassName name of Java class of WebDriver to use.
* @param profile profile to use (for firefox, chrome mobile and IE only for now)
* @return true if instance was created and injected into SeleniumHelper.
* @throws Exception if no instance could be created.
*/
public boolean startDriver(String driverClassName, final Map profile) throws Exception {
if (OVERRIDE_ACTIVE) {
return true;
}
DriverFactory driverFactory = new LocalDriverFactory(driverClassName, profile);
WebDriver driver = setAndUseDriverFactory(driverFactory);
return driver != null;
}
/**
* Creates an instance of the specified class an injects it into SeleniumHelper, so other fixtures can use it.
*
* @param driverClassName name of Java class of WebDriver to use.
* @return true if instance was created and injected into SeleniumHelper.
* @throws Exception if no instance could be created.
*/
public boolean startDriver(String driverClassName) throws Exception {
return startDriver(driverClassName, null);
}
/**
* Starts a local instance of the selenium driver for the specified browser
* (using defaults to determine the correct class and configuration properties).
* and injects it into SeleniumHelper, so other fixtures can use it.
*
* @param browser name of browser to connect to.
* @param profile setting of the browser (for firefox, chrome mobile and IE only for now)
* @return true if instance was created and injected into SeleniumHelper.
* @throws Exception if no instance could be created.
*/
public boolean startDriverForWithProfile(String browser, Map profile) throws Exception {
if (OVERRIDE_ACTIVE) {
return true;
}
DriverFactory driverFactory = new ProjectDriverFactoryFactory().create(browser, profile);
WebDriver driver = setAndUseDriverFactory(driverFactory);
return driver != null;
}
public boolean startDriverFor(String browser) throws Exception {
return startDriverForWithProfile(browser, null);
}
/**
* Connects SeleniumHelper to a remote web driver, without specifying browser version.
*
* @param browser name of browser to connect to.
* @param url url to connect to browser.
* @return true.
* @throws MalformedURLException if supplied url can not be transformed to URL.
*/
public boolean connectToDriverForAt(String browser, String url)
throws MalformedURLException {
return connectToDriverForVersionOnAt(browser, "", Platform.ANY.name(), url);
}
/**
* Connects SeleniumHelper to a remote web driver, without specifying browser version.
*
* @param browser name of browser to connect to.
* @param platformName platform browser must run on.
* @param url url to connect to browser.
* @return true.
* @throws MalformedURLException if supplied url can not be transformed to URL.
*/
public boolean connectToDriverForOnAt(String browser, String platformName, String url)
throws MalformedURLException {
return connectToDriverForVersionOnAt(browser, "", platformName, url);
}
/**
* Connects SeleniumHelper to a remote web driver.
*
* @param browser name of browser to connect to.
* @param version version of browser.
* @param platformName platform browser must run on.
* @param url url to connect to browser.
* @return true.
* @throws MalformedURLException if supplied url can not be transformed to URL.
*/
public boolean connectToDriverForVersionOnAt(String browser, String version, String platformName, String url)
throws MalformedURLException {
Platform platform = Platform.valueOf(platformName);
DesiredCapabilities desiredCapabilities = new DesiredCapabilities(browser, version, platform);
desiredCapabilities.setVersion(version);
return createAndSetRemoteDriver(url, desiredCapabilities);
}
public boolean connectToDriverAtWithCapabilities(String url, Map capabilities)
throws MalformedURLException {
DesiredCapabilities desiredCapabilities = new DesiredCapabilities(capabilities);
return createAndSetRemoteDriver(url, desiredCapabilities);
}
public boolean connectToFirefoxDriverAtWithProfile(String url, Map profile)
throws MalformedURLException {
FirefoxProfile fxProfile = getFirefoxProfile(profile);
FirefoxOptions desiredCapabilities = new FirefoxOptions();
desiredCapabilities.setCapability("browserName", "firefox");
desiredCapabilities.setProfile(fxProfile);
return createAndSetRemoteDriver(url, desiredCapabilities);
}
public boolean connectToDriverAtWithJsonCapabilities(String url, String capabilitiesInJson)
throws MalformedURLException {
Map desiredCapabilities = getEnvironment().getJsonHelper().jsonStringToMap(capabilitiesInJson);
return connectToDriverAtWithCapabilities(url, desiredCapabilities);
}
public String driverDescription() {
String result = null;
WebDriver driver = getHelper().driver();
if (driver != null) {
StringBuilder builder = new StringBuilder("");
builder.append("");
builder.append(driver.getClass().getName());
builder.append("
");
if (driver instanceof RemoteWebDriver) {
RemoteWebDriver remoteDriver = (RemoteWebDriver) driver;
URL lastRemoteUrl = getLastRemoteUrl();
if (lastRemoteUrl != null) {
builder.append(" at ");
builder.append(lastRemoteUrl.getHost());
builder.append("");
}
builder.append(describeCapabilities(remoteDriver));
builder.append(extendedDriverDescription(lastRemoteUrl));
}
builder.append("");
result = builder.toString();
}
return result;
}
public String runSummary() {
String result = null;
String sessionId = getHelper().getSessionId();
if (sessionId != null && !"".equals(sessionId)) {
URL lastRemoteUrl = getLastRemoteUrl();
if (lastRemoteUrl != null) {
if (SauceLabsHelper.isRelevant(lastRemoteUrl)) {
result = SauceLabsHelper.getTagToEmbedVideoOfRun(lastRemoteUrl, sessionId);
}
}
}
getEnvironment().setSymbol(LAST_RUN_SUMMARY, result);
return result;
}
public static String getLastRunSummary() {
return Environment.getInstance().getSymbol(LAST_RUN_SUMMARY);
}
protected String describeCapabilities(RemoteWebDriver remoteDriver) {
Capabilities capabilities = remoteDriver.getCapabilities();
Map capaToShow = getCapabilitiesToDescribe(capabilities);
StringBuilder result = new StringBuilder("");
for (Map.Entry entry : capaToShow.entrySet()) {
result.append("");
result.append(entry.getKey());
result.append(" ");
result.append(entry.getValue());
result.append(" ");
}
result.append("
");
return result.toString();
}
protected Map getCapabilitiesToDescribe(Capabilities capabilities) {
Map result = capabilities.asMap();
Collection keysToMask = getSecretCapabilities();
if (!keysToMask.isEmpty()) {
result = getEnvironment().getSecretMasker().replaceSecrets(keysToMask, result);
}
return result;
}
protected String extendedDriverDescription(URL lastRemoteUrl) {
String result = "";
if (SauceLabsHelper.isRelevant(lastRemoteUrl)) {
String jobLink = SauceLabsHelper.getJobLink(lastRemoteUrl, getHelper().getSessionId());
result = String.format("Job details", jobLink);
}
return result;
}
protected boolean createAndSetRemoteDriver(String url, final Capabilities desiredCapabilities)
throws MalformedURLException {
return createAndSetRemoteWebDriver(RemoteWebDriver::new, url, desiredCapabilities);
}
protected boolean createAndSetRemoteWebDriver(BiFunction constr,
String url,
Capabilities desiredCapabilities)
throws MalformedURLException {
if (OVERRIDE_ACTIVE) {
return true;
}
String cleanUrl = cleanupValue(url);
DriverFactory driverFactory = new RemoteDriverFactory(constr, cleanUrl, desiredCapabilities);
WebDriver driver = setAndUseDriverFactory(driverFactory);
return driver != null;
}
public static URL getLastRemoteUrl() {
URL result = null;
String urlValue = Environment.getInstance().getSymbol(REMOTE_URL_KEY);
if (urlValue != null) {
try {
result = new URL(urlValue);
} catch (MalformedURLException e) {
throw new RuntimeException(e);
}
}
return result;
}
protected WebDriver setAndUseDriverFactory(DriverFactory driverFactory) {
DriverManager driverManager = getEnvironment().getSeleniumDriverManager();
driverManager.setFactory(driverFactory);
return driverManager.getSeleniumHelper().driver();
}
/**
* Stops the current driver registered in the SeleniumHelper.
*
* @return true.
*/
public boolean stopDriver() {
if (OVERRIDE_ACTIVE) {
return true;
}
// ensure we store summary
runSummary();
getEnvironment().getSeleniumDriverManager().closeDriver();
return true;
}
public List getSecretCapabilities() {
return secretCapabilities;
}
/**
* Prevents instances from creating new Selenium drivers.
* This can be used to control Selenium configuration independent from Wiki content.
*/
public static void lockConfig() {
OVERRIDE_ACTIVE = true;
}
/**
* Enables normal behavior (i.e. instances can create new Selenium drivers).
*/
public static void unlockConfig() {
OVERRIDE_ACTIVE = false;
}
protected SeleniumHelper getHelper() {
return Environment.getInstance().getSeleniumHelper();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy