diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/Config.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/Config.java index 6c05bc35..a3e7697d 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/Config.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/Config.java @@ -24,6 +24,7 @@ public class Config { public static final String EDGEDRIVER = "edgedriver"; public static final String CHROME_DRIVER = "chromedriver"; public static final String GECKO_DRIVER = "geckodriver"; + public static final String MSEDGE_DRIVER = "msedgedriver"; public static final String SHARED_DIR = "expose_directory"; public static final String AUTO_START_NODE = "auto_start_node"; @@ -140,6 +141,7 @@ private void initialize() { initializeIEDriver(); initializeChromeDriver(); initializeGeckoDriver(); + initializeMsEdgeDriver(); getConfigMap().put(NODE_CONFIG_FILES, new LinkedList()); getConfigMap().put(HUB_CONFIG_FILES, new LinkedList()); @@ -215,6 +217,10 @@ private void initializeGeckoDriver() { getConfigMap().put(GECKO_DRIVER, new GeckoDriver()); } + private void initializeMsEdgeDriver() { + getConfigMap().put(MSEDGE_DRIVER, new MsEdgeDriver()); + } + public void addNodeConfigFile(String filename) { LinkedList files = (LinkedList) getConfigMap().get(NODE_CONFIG_FILES); files.add(filename); @@ -246,6 +252,7 @@ public static Config initilizedFromUserInput() { config.initializeIEDriver(); config.initializeChromeDriver(); config.initializeGeckoDriver(); + config.initializeMsEdgeDriver(); return FirstTimeRunConfig.customiseConfig(config); } @@ -337,6 +344,23 @@ public DriverInfo getGeckoDriver() { } } + public DriverInfo getMsEdgeDriver() { + try { + return (MsEdgeDriver) getConfigMap().get(MSEDGE_DRIVER); + } catch (ClassCastException e) { + LinkedTreeMap + stringMapFromGoogleWhoCantUseHashMapOnNestedObjects = + (LinkedTreeMap) getConfigMap().get(MSEDGE_DRIVER); + DriverInfo msEdgeDriver = new MsEdgeDriver(); + + msEdgeDriver.putAll(stringMapFromGoogleWhoCantUseHashMapOnNestedObjects); + + getConfigMap().put(MSEDGE_DRIVER, msEdgeDriver); + + return msEdgeDriver; + } + } + public DriverInfo getEdgeDriver() { try { EdgeDriver driver; diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/DefaultConfig.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/DefaultConfig.java index c262dcdc..8c6e8fc2 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/DefaultConfig.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/DefaultConfig.java @@ -93,6 +93,7 @@ public class DefaultConfig { private static final String ieDriverDefaultVersion = "2.53.1"; private static final String chromeDriverDefaultVersion = "2.22"; private static final String geckoDriverDefaultVersion = "0.10.0"; + private static final String msEdgeDriverDefaultVersion = "75.0.139.20"; public static Config getDefaultConfig() { config = new Config(); @@ -101,6 +102,7 @@ public static Config getDefaultConfig() { loadIEDriverInfo(); loadChromeDriverInfo(); loadGeckoDriverInfo(); + loadMsEdgeDriverInfo(); loadDisabledPlugins(); loadEnabledPlugins(); loadSetupConfig(); @@ -208,6 +210,10 @@ public static String getGeckoDriverDefaultVersion() { return geckoDriverDefaultVersion; } + public static String getMsEdgeDriverDefaultVersion() { + return msEdgeDriverDefaultVersion; + } + private static void loadSetupConfig() { config.addSetupTask(MoveMouse.class.getCanonicalName()); } @@ -256,6 +262,16 @@ private static void loadGeckoDriverInfo() { config.getGeckoDriver().setVersion(getGeckoDriverDefaultVersion()); } + private static void loadMsEdgeDriverInfo() { + String tmpDir; + + tmpDir = config.getWebdriver().getDirectory() + RuntimeConfig.getOS().getFileSeparator(); + + config.getMsEdgeDriver().setDirectory(tmpDir + "msedgedriver"); + config.getMsEdgeDriver().setVersion(getMsEdgeDriverDefaultVersion()); + config.getMsEdgeDriver().setBit(JsonCodec.WebDriver.Downloader.BIT_32); + } + private static void loadLogConfig() { config.setLogMaximumSize(LOG_MAXIMUM_SIZE); config.setLogMaximumAge(LOG_MAX_AGE); @@ -279,6 +295,7 @@ private static void loadEnabledPlugins() { config.addActivatedModules(KillAllFirefox.class.getCanonicalName()); config.addActivatedModules(KillAllChrome.class.getCanonicalName()); config.addActivatedModules(KillAllSafari.class.getCanonicalName()); + config.addActivatedModules(KillAllMsEdge.class.getCanonicalName()); config.addActivatedModules(SetAutoLogonUser.class.getCanonicalName()); config.addActivatedModules(GetProcesses.class.getCanonicalName()); @@ -305,6 +322,7 @@ private static void loadEnabledPlugins() { config.addActivatedModules(DownloadIEDriver.class.getCanonicalName()); config.addActivatedModules(DownloadChromeDriver.class.getCanonicalName()); config.addActivatedModules(DownloadGeckoDriver.class.getCanonicalName()); + config.addActivatedModules(DownloadMsEdgeDriver.class.getCanonicalName()); config.addActivatedModules(SessionHistory.class.getCanonicalName()); config.addActivatedModules(UpgradeGridExtrasTask.class.getCanonicalName()); diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/FirstTimeRunConfig.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/FirstTimeRunConfig.java index 678ae490..45822ee9 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/FirstTimeRunConfig.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/FirstTimeRunConfig.java @@ -47,6 +47,7 @@ import com.groupon.seleniumgridextras.config.remote.ConfigPusher; import com.groupon.seleniumgridextras.downloader.ChromeDriverDownloader; import com.groupon.seleniumgridextras.downloader.GeckoDriverDownloader; +import com.groupon.seleniumgridextras.downloader.MsEdgeDriverDownloader; import com.groupon.seleniumgridextras.downloader.webdriverreleasemanager.WebDriverReleaseManager; import com.groupon.seleniumgridextras.os.GridPlatform; import com.groupon.seleniumgridextras.tasks.SetAutoLogonUser; @@ -279,6 +280,7 @@ private static void setDriverAutoUpdater(Config defaultConfig) { WebDriverReleaseManager manager = RuntimeConfig.getReleaseManager(); String versionOfChrome = manager.getChromeDriverLatestVersion().getPrettyPrintVersion("."); String versionOfGecko = manager.getGeckoDriverLatestVersion().getPrettyPrintVersion("."); + String versionOfMsEdge = manager.getMsEdgeDriverLatestVersion().getPrettyPrintVersion("."); String versionOfWebDriver = manager.getWedriverLatestVersion().getPrettyPrintVersion("."); String versionOfIEDriver = manager.getIeDriverLatestVersion().getPrettyPrintVersion("."); @@ -298,9 +300,12 @@ private static void setDriverAutoUpdater(Config defaultConfig) { askQuestion("What version of Gecko Driver should we use?", versionOfGecko); versionOfChrome = askQuestion("What version of Chrome Driver should we use?", versionOfChrome); + versionOfMsEdge = + askQuestion("What version of MsEdge Driver should we use?", versionOfMsEdge); } defaultConfig.getChromeDriver().setVersion(versionOfChrome); defaultConfig.getGeckoDriver().setVersion(versionOfGecko); + defaultConfig.getMsEdgeDriver().setVersion(versionOfMsEdge); if(gridExtrasVersion.startsWith("1.")) { if(VersionCompare.versionCompare(versionOfWebDriver, "3.7.1") >= 0) { @@ -347,9 +352,21 @@ private static void setDriverAutoUpdater(Config defaultConfig) { } defaultConfig.getGeckoDriver().setBit(bitOfGeckoDriver); + String bitOfMsEdgeDriver = JsonCodec.WebDriver.Downloader.BIT_32; + String[] bitVersionsMsEdgeDriver = MsEdgeDriverDownloader.getBitArchitecturesForVersion(versionOfMsEdge); + if (bitVersionsMsEdgeDriver.length > 1) { + bitOfMsEdgeDriver = askQuestion("What bit of MsEdgeDriver should we use (" + StringUtils.join(bitVersionsMsEdgeDriver, ", ") + ")?", JsonCodec.WebDriver.Downloader.BIT_32); + } else if (bitVersionsMsEdgeDriver.length == 1) { + bitOfMsEdgeDriver = bitVersionsMsEdgeDriver[0]; + } else { + System.out.println("\nWARNING: We were unable to find the correct bit of MsEdgeDriver for this OS and MsEdgeDriver version: " + versionOfMsEdge + " so will default to '32' please update this to be more accurate, or grid may not function properly\n"); + } + defaultConfig.getMsEdgeDriver().setBit(bitOfMsEdgeDriver); + System.out.println("Current Selenium Driver Version: " + defaultConfig.getWebdriver().getVersion()); System.out.printf("Current Chrome Driver Version: %s (%s bit)\n", defaultConfig.getChromeDriver().getVersion(), defaultConfig.getChromeDriver().getBit()); System.out.printf("Current Gecko Driver Version: %s (%s bit)\n", defaultConfig.getGeckoDriver().getVersion(), defaultConfig.getGeckoDriver().getBit()); + System.out.printf("Current MsEdge Driver Version: %s (%s bit)\n", defaultConfig.getMsEdgeDriver().getVersion(), defaultConfig.getMsEdgeDriver().getBit()); if (defaultConfig.getIEdriver() != null && defaultConfig.getIEdriver().getVersion() != null) { System.out.printf("Current IE Driver Version: %s (%s bit)\n", defaultConfig.getIEdriver().getVersion(), defaultConfig.getIEdriver().getBit()); diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/RuntimeConfig.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/RuntimeConfig.java index 7ff3708d..17037e89 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/RuntimeConfig.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/RuntimeConfig.java @@ -76,7 +76,8 @@ public static WebDriverReleaseManager getReleaseManager() { releaseManager = loadWebDriverReleaseManager("https://selenium-release.storage.googleapis.com/", "https://chromedriver.storage.googleapis.com/LATEST_RELEASE", - "https://api.github.com/repos/mozilla/geckodriver/releases"); + "https://api.github.com/repos/mozilla/geckodriver/releases", + "https://msedgedriver.azureedge.net/LATEST_STABLE"); } return releaseManager; @@ -85,11 +86,13 @@ public static WebDriverReleaseManager getReleaseManager() { private static WebDriverReleaseManager loadWebDriverReleaseManager(String webDriverAndIEDriverURL, String chromeDriverUrl, - String geckoDriverUrl) { + String geckoDriverUrl, + String msEdgeDriverUrl) { try { return new WebDriverReleaseManager(new URL(webDriverAndIEDriverURL), new URL(chromeDriverUrl), - new URL(geckoDriverUrl)); + new URL(geckoDriverUrl), + new URL(msEdgeDriverUrl)); } catch (MalformedURLException e) { logger.error("Seems that " + webDriverAndIEDriverURL + " is malformed"); logger.error(e.toString()); diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/BrowserType.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/BrowserType.java index 72c8957b..e82ac828 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/BrowserType.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/BrowserType.java @@ -10,6 +10,7 @@ public interface BrowserType { String FIREFOX = "firefox"; + @Deprecated String EDGE = "MicrosoftEdge"; @Deprecated @@ -32,6 +33,7 @@ public interface BrowserType { @Deprecated String SAFARI_PROXY = "safariproxy"; String CHROME = "chrome"; + String MSEDGE = "MicrosoftEdge"; @Deprecated String KONQUEROR = "konqueror"; @Deprecated diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/Capability.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/Capability.java index cba5afdd..49828320 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/Capability.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/Capability.java @@ -104,8 +104,9 @@ public static Map getSupportedWebCapabilities() { capabilityHash.put(Firefox.class, BrowserType.FIREFOX); capabilityHash.put(InternetExplorer.class, BrowserType.IE); - capabilityHash.put(Edge.class, BrowserType.EDGE); + // capabilityHash.put(Edge.class, BrowserType.EDGE); capabilityHash.put(Chrome.class, BrowserType.CHROME); + capabilityHash.put(MsEdge.class, BrowserType.MSEDGE); capabilityHash.put(Safari.class, BrowserType.SAFARI); capabilityHash.put(PhantomJs.class, BrowserType.PHANTOMJS); diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/MsEdge.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/MsEdge.java new file mode 100644 index 00000000..19f1c9a2 --- /dev/null +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/capabilities/MsEdge.java @@ -0,0 +1,14 @@ +package com.groupon.seleniumgridextras.config.capabilities; + +public class MsEdge extends Capability { + + @Override + public String getWebDriverClass() { + return "org.openqa.selenium.edge.EdgeDriver"; + } + + @Override + public String getIcon() { + return "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAALZSURBVDhPXVNfSFNRGP/OOffPNnRRGK5CysiYFFH4kpAPkeJDFPXSWy8FpVAo/YMeepDs1ZdQsN56iDAMLBRBEkQwC4UgI825XDXnrmNzm3Nzu+ecvnPvJPQ3zs653zm/3/2+33cPgV1oiEZ9esS4otmFC4TkDxOSJoQlY5Ran/PGxrvpM+3R8lEHOwTOTmWushLpY1IEkIyRLFCyDkgGRmJA6O+S0OK9xarA44naroLiUPWn0DiZ69C3PINUsACAxJ9AdYE7HGcb5yLOBd2QG50VmeXxy2sPKxXPETg3mW9mttGDSyKFAG4rksRHV8AZxMYYilAJOuGNNJF8gRtAGmZmdE/m1Pd4OFIXi6zAZq4IkmpgGAz2H9ThaNAG02NhGX+A0TBoWgKYyYDpTIKhN1IzfbLl55evdaH5v5CTfpD+GoDKQ1A0qyFqVcLstAZ2qWwVJqXyUiAECANxnS7PLbauJYsAFQcAzD0AzMBdCiSVmADBgpsF//HVFe84biANh1KQ6JESkxCklpU9Ar4ql1gGC38DbWXpDnTXL0D3icV9e/O3QGrINZCE7qA1yivJeZbazF/aJqtESSYJNIU1C3DapOCtACxYx5UHBfQyGbOwxQBFR0LuMTc7mracErgoXnSjGGfeB1gfkn3OEEjmnPcP1r96g20kY+VzLoruiwkXT8xLL4+pNfd5HoHQ26Q0e4TwPrNtren96ddtqtcEBiSD+fAc2hpUh9FVYImYkwVmtIo1t/Ohm0MY2G4Afu/9uhnI1WwN3wu7/en6dR6IGEMRRtYt0BZmADTT2VKQUkZQYApbl5JSVIGwmyQv3OAj90f/34Wn4dt4tE+9mv34BDSbxnYo43aB20LyYqc90vFcPe64TNC11IK3p5dwu46GZvFbsFAORbAcZTG6H5LEvss/dIy6hN0CCo4ny61YcjNZj9eSeISQbCqCPfvIzepheHtNXY4yAP4BZck/RGFnkbYAAAAASUVORK5CYII="; + } +} diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/driver/MsEdgeDriver.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/driver/MsEdgeDriver.java new file mode 100644 index 00000000..0865e58b --- /dev/null +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/config/driver/MsEdgeDriver.java @@ -0,0 +1,62 @@ +/** + * Copyright (c) 2013, Groupon, Inc. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * + * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * Neither the name of GROUPON nor the names of its contributors may be + * used to endorse or promote products derived from this software without + * specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A + * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED + * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + * Created with IntelliJ IDEA. + * User: Dima Kovalenko (@dimacus) && Darko Marinov + * Date: 5/10/13 + * Time: 4:06 PM + */ +package com.groupon.seleniumgridextras.config.driver; + +import com.groupon.seleniumgridextras.config.RuntimeConfig; + +public class MsEdgeDriver extends DriverInfo { + + @Override + public String getExecutablePath() { + + String + path = + this.getDirectory() + RuntimeConfig.getOS().getFileSeparator() + getExecutableName(); + + return path; + } + + @Override + public String getExecutableName() { + String exe = "msedgedriver_" + this.getVersion() + "_" + this.getBit() + "bit"; + + if (RuntimeConfig.getOS().isWindows()) { + exe = exe + ".exe"; + } + return exe; + } +} diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/MsEdgeDriverDownloader.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/MsEdgeDriverDownloader.java new file mode 100644 index 00000000..cb4dbf91 --- /dev/null +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/MsEdgeDriverDownloader.java @@ -0,0 +1,219 @@ +/** + * Copyright (c) 2013, Groupon, Inc. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * + * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * Neither the name of GROUPON nor the names of its contributors may be + * used to endorse or promote products derived from this software without + * specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A + * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED + * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + * Created with IntelliJ IDEA. + * User: Dima Kovalenko (@dimacus) && Darko Marinov + * Date: 5/10/13 + * Time: 4:06 PM + */ + +package com.groupon.seleniumgridextras.downloader; + +import com.groupon.seleniumgridextras.config.RuntimeConfig; + +import org.apache.log4j.Logger; +import org.w3c.dom.NodeList; +import org.xml.sax.SAXException; +import org.w3c.dom.Document; + +import javax.xml.parsers.DocumentBuilderFactory; +import javax.xml.parsers.ParserConfigurationException; +import javax.xml.xpath.*; +import java.io.File; +import java.io.IOException; +import java.net.URL; +import java.util.ArrayList; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +public class MsEdgeDriverDownloader extends Downloader { + + private String bit; + private String version; + + private static final String MSEDGEDRIVER_BASE_URL = "https://msedgedriver.azureedge.net/"; + + private static Logger logger = Logger.getLogger(MsEdgeDriverDownloader.class); + + public MsEdgeDriverDownloader(String version, String bitVersion) { + + setDestinationDir(RuntimeConfig.getConfig().getMsEdgeDriver().getDirectory()); + setVersion(version); + setBitVersion(bitVersion); + + setDestinationFile(getVersion() + "_" + getBitVersion() + "bit" + ".zip"); + + setSourceURL(MSEDGEDRIVER_BASE_URL + getVersion() + "/edgedriver_" + + getOSName() + getBitVersion() + ".zip"); + } + + @Override + public void setSourceURL(String source) { + sourceURL = source; + } + + @Override + public void setDestinationFile(String destination) { + destinationFile = destination; + } + + @Override + public void setDestinationDir(String dir) { + destinationDir = dir; + } + + @Override + public boolean download() { + + logger.info("Downloading from " + getSourceURL()); + + if (startDownload()) { + + if (Unzipper.unzip(getDestinationFileFullPath().getAbsolutePath(), getDestinationDir())) { + + String msedgedriver = "msedgedriver"; + if (RuntimeConfig.getOS().isWindows()){ + msedgedriver = msedgedriver + ".exe"; + } + + File tempUnzipedExecutable = new File(getDestinationDir(), msedgedriver); + File finalExecutable = + new File(RuntimeConfig.getConfig().getMsEdgeDriver().getExecutablePath()); + + if (tempUnzipedExecutable.exists()){ + logger.debug(tempUnzipedExecutable.getAbsolutePath()); + logger.debug("It does exist"); + logger.debug(finalExecutable.getAbsolutePath()); + } else { + logger.debug(tempUnzipedExecutable.getAbsolutePath()); + logger.debug("NO exist"); + logger.debug(finalExecutable.getAbsolutePath()); + } + + tempUnzipedExecutable.renameTo(finalExecutable); + + setDestinationFile(finalExecutable.getAbsolutePath()); + + finalExecutable.setExecutable(true, false); + finalExecutable.setReadable(true, false); + + return true; + } + } + return false; + } + + + public String getBitVersion() { + return bit; + } + + public void setBitVersion(String bit) { + this.bit = bit; + } + + public String getVersion() { + return version; + } + + public void setVersion(String version) { + this.version = version; + } + + protected static String getOSName() { + String os; + + if (RuntimeConfig.getOS().isWindows()) { + os = getWindowsName(); + } else if (RuntimeConfig.getOS().isMac()) { + os = getMacName(); + } else { + os = getLinuxName(); + } + + return os; + } + + protected static String getLinuxName() { + return "linux"; + } + + protected static String getMacName() { + return "mac"; + } + + protected static String getWindowsName() { + return "win"; + } + + public static String[] getBitArchitecturesForVersion(String edgeDriverVersionNumber) { + // ArrayList bitArchitecturesAvailable = new ArrayList(); + // try { + // String xpathString = "//*[text()[contains(.,'" + edgeDriverVersionNumber + "/edgedriver_" + getOSName() + "')]]"; + // XPathExpression expression = XPathFactory.newInstance().newXPath().compile(xpathString); + + // NodeList result = (NodeList) expression.evaluate(getVersionManifest(), XPathConstants.NODESET); + + // for (int i = 0; i < result.getLength(); i++) { + // String nodeValue = result.item(i).getTextContent(); + // Matcher matcher = Pattern.compile("(\\d{2})(?=.zip)").matcher(nodeValue); + // while (matcher.find()) + // { + // bitArchitecturesAvailable.add(matcher.group(1)); + // } + // } + // } + // catch (XPathExpressionException e) { + // logger.error(e.toString()); + // } + // finally { + // return bitArchitecturesAvailable.toArray(new String[] {}); + // } + return new String[] { "32", "64" }; + } + + private static Document getVersionManifest() { + DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); + try { + return factory.newDocumentBuilder().parse(new URL(MSEDGEDRIVER_BASE_URL).openStream()); + } + catch (ParserConfigurationException pce) { + logger.error(pce.toString()); + } + catch (SAXException se) { + logger.error(se.toString()); + } + catch (IOException ioe) { + logger.error(ioe.toString()); + } + return null; + } +} diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/MsEdgeDriverRelease.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/MsEdgeDriverRelease.java new file mode 100644 index 00000000..d8658b3f --- /dev/null +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/MsEdgeDriverRelease.java @@ -0,0 +1,49 @@ +package com.groupon.seleniumgridextras.downloader.webdriverreleasemanager; + + +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +public class MsEdgeDriverRelease extends WebDriverRelease { + + private int buildVersion; + + public MsEdgeDriverRelease(String input) { + super(input); + + Matcher m = Pattern.compile("(\\d+)\\.(\\d+)\\.(\\d+)\\.(\\d+)").matcher(input); + + if (m.find()){ + setMajorVersion(Integer.valueOf(m.group(1))); + setMinorVersion(Integer.valueOf(m.group(2))); + setBuildVersion(Integer.valueOf(m.group(3))); + setPatchVersion(Integer.valueOf(m.group(4))); + } + + setName("msedgedriver"); + setRelativePath("index.html?path=" + getPrettyPrintVersion(".") + "/"); + } + + public String getPrettyPrintVersion(String separator){ + StringBuilder stringBuilder = new StringBuilder(); + + stringBuilder.append(getMajorVersion()); + stringBuilder.append(separator); + stringBuilder.append(getMinorVersion()); + stringBuilder.append(separator); + stringBuilder.append(getBuildVersion()); + stringBuilder.append(separator); + stringBuilder.append(getPatchVersion()); + + return stringBuilder.toString(); + } + + public int getBuildVersion() { + return buildVersion; + } + + public void setBuildVersion(int buildVersion) { + this.buildVersion = buildVersion; + } + +} diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/WebDriverRelease.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/WebDriverRelease.java index a47380db..ad82686d 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/WebDriverRelease.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/WebDriverRelease.java @@ -31,10 +31,7 @@ public WebDriverRelease(String input) { setName(detailedMatcher.group(3)); } - } - - } public String getPrettyPrintVersion(String separator){ diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/WebDriverReleaseManager.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/WebDriverReleaseManager.java index 4a290573..30f2e103 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/WebDriverReleaseManager.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/downloader/webdriverreleasemanager/WebDriverReleaseManager.java @@ -27,15 +27,16 @@ public class WebDriverReleaseManager { private static final String IE_DRIVER = "ie-driver"; private static final String CHROME_DRIVER = "chrome-driver"; private static final String GECKO_DRIVER = "gecko-driver"; + private static final String MSEDGE_DRIVER = "msedge-driver"; private WebDriverRelease latestWebdriverVersion; private WebDriverRelease latestIEDriverVersion; private WebDriverRelease latestChromeDriverVersion; private WebDriverRelease latestGeckoDriverVersion; + private WebDriverRelease latestMsEdgeDriverVersion; private Document parsedXml; private static Logger logger = Logger.getLogger(WebDriverReleaseManager.class); - private Map> allProducts; private void initialize() { @@ -44,13 +45,17 @@ private void initialize() { allProducts.put(IE_DRIVER, new LinkedList()); allProducts.put(CHROME_DRIVER, new LinkedList()); allProducts.put(GECKO_DRIVER, new LinkedList()); + allProducts.put(MSEDGE_DRIVER, new LinkedList()); } - public WebDriverReleaseManager(URL webDriverAndIEDriverURL, URL chromeDriverVersionURL, URL geckoDriverVersionURL) + public WebDriverReleaseManager(URL webDriverAndIEDriverURL, URL chromeDriverVersionURL, URL geckoDriverVersionURL, URL msEdgeDriverVersionURL) throws DocumentException { - logger.info("Checking the latest version of WebDriver, IEDriver, ChromeDriver and GeckoDriver from " - + webDriverAndIEDriverURL.toExternalForm() + " and " + chromeDriverVersionURL + " and " + geckoDriverVersionURL + logger.info("Checking the latest version of WebDriver, IEDriver, ChromeDriver, GeckoDriver, MsEdgeDriver from " + + webDriverAndIEDriverURL.toExternalForm() + " and " + + chromeDriverVersionURL + " and " + + geckoDriverVersionURL + " and " + + msEdgeDriverVersionURL .toExternalForm()); initialize(); @@ -59,6 +64,7 @@ public WebDriverReleaseManager(URL webDriverAndIEDriverURL, URL chromeDriverVers loadWebDriverAndIEDriverVersions(parsedXml); loadChromeDriverVersionFromURL(chromeDriverVersionURL); loadGeckoDriverVersionFromURL(geckoDriverVersionURL); + loadMsEdgeDriverVersionFromURL(msEdgeDriverVersionURL); } public int getWebdriverVersionCount() { @@ -94,6 +100,10 @@ public WebDriverRelease getGeckoDriverLatestVersion() { return this.latestGeckoDriverVersion; } + public WebDriverRelease getMsEdgeDriverLatestVersion() { + return this.latestMsEdgeDriverVersion; + } + /* * Choose the greatest major version. * If major version is the same, choose the greatest comparable version. @@ -154,6 +164,24 @@ public void loadGeckoDriverVersion(String version) { this.latestGeckoDriverVersion = new GeckoDriverRelease(version); } + public void loadMsEdgeDriverVersionFromURL(URL url) { + InputStream in = null; + try { + in = url.openStream(); + loadMsEdgeDriverVersion(IOUtils.toString(in, "UTF-16LE")); + } catch (IOException e) { + logger.error("Something went wrong when trying to get latest msedge driver version"); + logger.error(e.toString()); + e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates. + } finally { + IOUtils.closeQuietly(in); + } + } + + public void loadMsEdgeDriverVersion(String version) { + this.latestMsEdgeDriverVersion = new MsEdgeDriverRelease(version); + } + public void loadWebDriverAndIEDriverVersions(Document xml) { Element root = xml.getRootElement(); for (Iterator i = root.elementIterator("Contents"); i.hasNext(); ) { diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/grid/GridStarter.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/grid/GridStarter.java index 6dadd92c..1a76a895 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/grid/GridStarter.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/grid/GridStarter.java @@ -202,11 +202,12 @@ protected static List getWebNodeStartCommand(String configFile, Boolean } if (windows) { command.add(getIEDriverExecutionPathParam(config)); - command.add(getEdgeDriverExecutionPathParam(config)); + // command.add(getEdgeDriverExecutionPathParam(config)); } command.add(getChromeDriverExecutionPathParam(config)); command.add(getGeckoDriverExecutionPathParam(config)); + command.add(getMsEdgeDriverExecutionPathParam(config)); command.add("-cp"); String cp = getGridExtrasJarFilePath(); @@ -294,6 +295,10 @@ protected static String getGeckoDriverExecutionPathParam(Config config) { return String.format("-Dwebdriver.gecko.driver=%s", config.getGeckoDriver().getExecutablePath()); } + protected static String getMsEdgeDriverExecutionPathParam(Config config) { + return String.format("-Dwebdriver.edge.driver=%s", config.getMsEdgeDriver().getExecutablePath()); + } + protected static String buildBackgroundStartCommand(String command, Boolean windows) { String backgroundCommand; final String batchFile = "start_hub.bat"; diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/DownloadMsEdgeDriver.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/DownloadMsEdgeDriver.java new file mode 100644 index 00000000..fe27c51e --- /dev/null +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/DownloadMsEdgeDriver.java @@ -0,0 +1,180 @@ +/** + * Copyright (c) 2013, Groupon, Inc. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * + * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * Neither the name of GROUPON nor the names of its contributors may be + * used to endorse or promote products derived from this software without + * specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A + * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED + * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + * Created with IntelliJ IDEA. + * User: Dima Kovalenko (@dimacus) && Darko Marinov + * Date: 5/10/13 + * Time: 4:06 PM + */ + +package com.groupon.seleniumgridextras.tasks; + +import com.google.gson.JsonObject; + +import com.groupon.seleniumgridextras.config.RuntimeConfig; +import com.groupon.seleniumgridextras.downloader.MsEdgeDriverDownloader; +import com.groupon.seleniumgridextras.downloader.Downloader; +import com.groupon.seleniumgridextras.tasks.config.TaskDescriptions; +import com.groupon.seleniumgridextras.utilities.json.JsonCodec; + +import org.apache.log4j.Logger; + +import java.io.File; +import java.util.Map; + +public class DownloadMsEdgeDriver extends ExecuteOSTask { + + private String bit = JsonCodec.WebDriver.Downloader.BIT_32; + private static Logger logger = Logger.getLogger(DownloadMsEdgeDriver.class); + + public DownloadMsEdgeDriver() { + setEndpoint(TaskDescriptions.Endpoints.DOWNLOAD_MSEDGEDRIVER); + setDescription(TaskDescriptions.Description.DOWNLOAD_MSEDGEDRIVER); + JsonObject params = new JsonObject(); + params.addProperty(JsonCodec.WebDriver.Downloader.VERSION, + "Version of MsEdgeDriver to download, such as 76.0.182.22"); + params.addProperty(JsonCodec.WebDriver.Downloader.BIT, + "Bit Version of MsEdgeDriver 32/64 - (default: 32)"); + setAcceptedParams(params); + setRequestType(TaskDescriptions.HTTP.GET); + setResponseType(TaskDescriptions.HTTP.JSON); + setClassname(this.getClass().getCanonicalName().toString()); + setCssClass(TaskDescriptions.UI.BTN_SUCCESS); + setButtonText(TaskDescriptions.UI.ButtonText.DOWNLOAD_MSEDGEDRIVER); + setEnabledInGui(true); + + addResponseDescription(JsonCodec.WebDriver.Downloader.ROOT_DIR, + "Directory to which executable file was saved to"); + addResponseDescription(JsonCodec.WebDriver.Downloader.FILE, + "Relative path to file on the node"); + addResponseDescription(JsonCodec.WebDriver.Downloader.FILE_FULL_PATH, + "Full path to file on node"); + addResponseDescription(JsonCodec.WebDriver.Downloader.SOURCE_URL, + "Url from which the executable was downloaded. If file already exists, this will be blank, and download will be skipped"); + + // bit value should be initialized from configuration + this.bit = RuntimeConfig.getConfig().getMsEdgeDriver().getBit(); + + logger.debug(RuntimeConfig.getConfig()); + getJsonResponse() + .addKeyValues(JsonCodec.WebDriver.Downloader.ROOT_DIR, + RuntimeConfig.getConfig().getMsEdgeDriver().getDirectory()); + getJsonResponse().addKeyValues( + JsonCodec.WebDriver.Downloader.SOURCE_URL, ""); + + } + + @Override + public JsonObject execute() { + return execute(RuntimeConfig.getConfig().getMsEdgeDriver().getVersion()); + } + + @Override + public JsonObject execute(Map parameter) { + + if (!parameter.isEmpty() && parameter.containsKey( + JsonCodec.WebDriver.Downloader.VERSION)) { + if (parameter.containsKey(JsonCodec.WebDriver.Downloader.BIT)) { + this.bit = parameter.get(JsonCodec.WebDriver.Downloader.BIT).toString(); + } else { + this.bit = JsonCodec.WebDriver.Downloader.BIT_32; + } + return execute(parameter.get(JsonCodec.WebDriver.Downloader.VERSION).toString()); + } else { + return execute(); + } + } + + @Override + public JsonObject execute(String version) { + Downloader + downloader = + new MsEdgeDriverDownloader(version, this.bit); + + if (!new File(RuntimeConfig.getConfig().getMsEdgeDriver().getExecutablePath()).exists()) { + Boolean downloaded = downloader.download(); + getJsonResponse().addKeyValues( + JsonCodec.WebDriver.Downloader.SOURCE_URL, downloader.getSourceURL()); + + if (!downloaded) { + getJsonResponse().addKeyValues(JsonCodec.ERROR, downloader.getErrorMessage()); + } + } else { + logger.debug("No need for download"); + getJsonResponse() + .addKeyValues(JsonCodec.OUT, "File already downloaded, will not download again"); + } + + getJsonResponse() + .addKeyValues(JsonCodec.WebDriver.Downloader.FILE_FULL_PATH, + downloader.getDestinationFileFullPath().getAbsolutePath()); + + getJsonResponse() + .addKeyValues(JsonCodec.WebDriver.Downloader.FILE, + downloader.getDestinationFileFullPath().getName()); + + return getJsonResponse().getJson(); + } + + @Override + public boolean initialize() { + + try { + File + msEdgeDriverExecutable = + new File(RuntimeConfig.getConfig().getMsEdgeDriver().getExecutablePath()); + File msEdgeDriverHome = new File(RuntimeConfig.getConfig().getMsEdgeDriver().getDirectory()); + + if (!msEdgeDriverHome.exists()) { + msEdgeDriverHome.mkdir(); + } + + if (!msEdgeDriverExecutable.exists()) { + systemAndLog("Downloading MsEdge Driver " + RuntimeConfig.getConfig().getMsEdgeDriver() + .getVersion()); + logger.info(execute().toString()); + } + + + } catch (NullPointerException error) { + printInitilizedFailure(); + logger.error(error); + return false; + } + + printInitilizedSuccessAndRegisterWithAPI(); + return true; + + } + + +} + diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/KillAllMsEdge.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/KillAllMsEdge.java new file mode 100644 index 00000000..cf25e913 --- /dev/null +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/KillAllMsEdge.java @@ -0,0 +1,73 @@ +/** + * Copyright (c) 2013, Groupon, Inc. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * + * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * Neither the name of GROUPON nor the names of its contributors may be + * used to endorse or promote products derived from this software without + * specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A + * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED + * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + * Created with IntelliJ IDEA. + * User: Dima Kovalenko (@dimacus) && Darko Marinov + * Date: 5/10/13 + * Time: 4:06 PM + */ + +package com.groupon.seleniumgridextras.tasks; + +import com.google.gson.JsonObject; + +import com.groupon.seleniumgridextras.tasks.config.TaskDescriptions; + +public class KillAllMsEdge extends KillAllByName { + + public KillAllMsEdge() { + setEndpoint(TaskDescriptions.Endpoints.KILL_MSEDGE); + setDescription(TaskDescriptions.Description.KILL_MSEDGE); + JsonObject params = new JsonObject(); + setAcceptedParams(params); + setRequestType("GET"); + setResponseType("json"); + setClassname(this.getClass().getCanonicalName().toString()); + setCssClass(TaskDescriptions.UI.BTN_DANGER); + setButtonText(TaskDescriptions.UI.ButtonText.KILL_MSEDGE); + setEnabledInGui(true); + } + + @Override + public String getWindowsCommand() { + return super.getWindowsCommand("msedge.exe"); + } + + @Override + public String getLinuxCommand() { + return super.getLinuxCommand("msedge"); + } + + @Override + public String getMacCommand() { + return super.getMacCommand("msedge"); + } +} diff --git a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/config/TaskDescriptions.java b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/config/TaskDescriptions.java index f3772372..2ad82690 100644 --- a/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/config/TaskDescriptions.java +++ b/SeleniumGridExtras/src/main/java/com/groupon/seleniumgridextras/tasks/config/TaskDescriptions.java @@ -7,6 +7,7 @@ public static class Endpoints { public static final String DOWNLOAD_CHROMEDRIVER = "/download_chromedriver"; public static final String DOWNLOAD_GECKODRIVER = "/download_geckodriver"; public static final String DOWNLOAD_IEDRIVER = "/download_iedriver"; + public static final String DOWNLOAD_MSEDGEDRIVER = "/download_msedgedriver"; public static final String DOWNLOAD_WEBDRIVER = "/download_webdriver"; public static final String DIR = "/dir"; public static final String CONFIG = "/config"; @@ -21,6 +22,7 @@ public static class Endpoints { public static final String KILL_CHROME = "/kill_chrome"; public static final String KILL_FIREFOX = "/kill_firefox"; public static final String KILL_IE = "/kill_ie"; + public static final String KILL_MSEDGE = "/kill_msedge"; public static final String KILL_SAFARI = "/kill_safari"; public static final String KILL_PID = "/kill_pid"; public static final String MOVE_MOUSE = "/move_mouse"; @@ -58,6 +60,9 @@ public static class Description { String DOWNLOAD_IEDRIVER = "Downloads a version of IEDriver.exe to local machine"; public static final + String DOWNLOAD_MSEDGEDRIVER = + "Downloads a version of MsEdgeDriver to local machine"; + public static final String DOWNLOAD_WEBDRIVER = "Downloads a version of WebDriver jar to local machine"; public static final @@ -100,6 +105,10 @@ public static class Description { KILL_IE = "Executes os level kill command on all instance of Internet Explorer"; public static final + String + KILL_MSEDGE = + "Executes os level kill command on all instance of Microsoft Edge"; + public static final String KILL_SAFARI = "Executes os level kill command on all instance of Safari"; @@ -159,6 +168,7 @@ public static class ButtonText { public static final String DOWNLOAD_CHROMEDRIVER = "Download Chrome-Driver"; public static final String DOWNLOAD_GECKODRIVER = "Download Gecko-Driver"; public static final String DOWNLOAD_IEDRIVER = "Download IE-Driver"; + public static final String DOWNLOAD_MSEDGEDRIVER = "Download MsEdge-Driver"; public static final String DOWNLOAD_WEBDRIVER = "Download WebDriver"; public static final String DIR = "List Shared Dir"; public static final String CONFIG = "Get Config"; @@ -173,6 +183,7 @@ public static class ButtonText { public static final String KILL_CHROME = "Kill all chrome"; public static final String KILL_FIREFOX = "Kill all firefox"; public static final String KILL_IE = "Kill all IE"; + public static final String KILL_MSEDGE = "Kill all ms edge"; public static final String KILL_SAFARI = "Kill all Safari"; public static final String KILL_PID = "Kill PID"; public static final String MOVE_MOUSE = "Move mouse"; diff --git a/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/KillAllMsEdgeTest.java b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/KillAllMsEdgeTest.java new file mode 100644 index 00000000..9026fafa --- /dev/null +++ b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/KillAllMsEdgeTest.java @@ -0,0 +1,72 @@ +/** + * Copyright (c) 2013, Groupon, Inc. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * + * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * Neither the name of GROUPON nor the names of its contributors may be + * used to endorse or promote products derived from this software without + * specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A + * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED + * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + * Created with IntelliJ IDEA. + * User: Dima Kovalenko (@dimacus) && Darko Marinov + * Date: 5/10/13 + * Time: 4:06 PM + */ + +package com.groupon.seleniumgridextras; + +import com.groupon.seleniumgridextras.tasks.ExecuteOSTask; +import com.groupon.seleniumgridextras.tasks.KillAllMsEdge; + +import org.junit.Before; +import org.junit.Test; + +import static org.junit.Assert.assertEquals; + +public class KillAllMsEdgeTest { + + private ExecuteOSTask task; + private String windowsCommand; + private String linuxCommnad; + private String macCommand; + + @Before + public void setUp() throws Exception { + task = new KillAllMsEdge(); + windowsCommand = "taskkill -F -IM msedge.exe"; + linuxCommnad = "killall -v -m msedge"; + macCommand = linuxCommnad; + } + + @Test + public void testGetDescription() throws Exception { + assertEquals("Executes os level kill command on all instance of Microsoft Edge", task.getDescription()); + } + + @Test + public void testGetEndpoint() throws Exception { + assertEquals("/kill_msedge", task.getEndpoint()); + } +} diff --git a/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/downloader/MsEdgeDriverDownloaderTest.java b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/downloader/MsEdgeDriverDownloaderTest.java new file mode 100644 index 00000000..9fa38c71 --- /dev/null +++ b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/downloader/MsEdgeDriverDownloaderTest.java @@ -0,0 +1,71 @@ +package com.groupon.seleniumgridextras.downloader; + +import com.groupon.seleniumgridextras.config.Config; +import com.groupon.seleniumgridextras.config.RuntimeConfig; + +import org.junit.After; +import org.junit.Before; +import org.junit.Test; + +import java.io.File; + +import static org.junit.Assert.assertEquals; + +public class MsEdgeDriverDownloaderTest { + + private MsEdgeDriverDownloader downloader; + private final String downloadDir = "/tmp/download_msedge_driver_test"; + + @Before + public void setUp() throws Exception { + RuntimeConfig.setConfigFile("msedge_download_test.json"); + Config config = new Config(); + + config.getMsEdgeDriver().setDirectory(downloadDir); + config.writeToDisk(RuntimeConfig.getConfigFile()); + RuntimeConfig.load(); + + + downloader = new MsEdgeDriverDownloader("76.0.182.22", "32"); + } + + @After + public void tearDown() throws Exception { + new File(RuntimeConfig.getConfigFile()).delete(); + new File(RuntimeConfig.getConfigFile() + ".example").delete(); + new File(downloader.getDestinationDir()).delete(); + } + + @Test + public void testSetSourceURL() throws Exception { + downloader.setSourceURL("microsoft.com"); + assertEquals("microsoft.com", downloader.getSourceURL()); + + } + + @Test + public void testSetDestinationDir() throws Exception { + assertEquals(downloadDir, downloader.getDestinationDir()); + downloader.setDestinationDir("temp"); + assertEquals("temp", downloader.getDestinationDir()); + } + + @Test + public void testSetBitVersion() throws Exception { + downloader.setBitVersion("64"); + assertEquals("64", downloader.getBitVersion()); + } + + @Test + public void testSetVersion() throws Exception { + downloader.setVersion("5"); + assertEquals("5", downloader.getVersion()); + } + + @Test + public void testGetOSNames() throws Exception { + assertEquals("mac", downloader.getMacName()); + assertEquals("win", downloader.getWindowsName()); + assertEquals("linux", downloader.getLinuxName()); + } +} diff --git a/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/downloader/WebDriverReleaseManagerTest.java b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/downloader/WebDriverReleaseManagerTest.java index 679ce968..b77f6238 100644 --- a/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/downloader/WebDriverReleaseManagerTest.java +++ b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/downloader/WebDriverReleaseManagerTest.java @@ -20,7 +20,8 @@ public void setUp() throws Exception { URL webDriverAndIEDriverURL = ClassLoader.getSystemResource("fixtures/selenium_release_manifest.xml"); URL chromeDriverVersionURL = ClassLoader.getSystemResource("fixtures/chromedriver_release_version.txt"); URL marionetteDriverVersionURL = ClassLoader.getSystemResource("fixtures/selenium_release_version.txt"); - releaseManager = new WebDriverReleaseManager(webDriverAndIEDriverURL, chromeDriverVersionURL, marionetteDriverVersionURL); + URL msEdgeDriverVersionURL = ClassLoader.getSystemResource("fixtures/msedgedriver_release_version.txt"); + releaseManager = new WebDriverReleaseManager(webDriverAndIEDriverURL, chromeDriverVersionURL, marionetteDriverVersionURL, msEdgeDriverVersionURL); } @Test @@ -34,6 +35,7 @@ public void testGetLatestVersion() throws Exception { assertEquals("2.41.0", releaseManager.getWedriverLatestVersion().getPrettyPrintVersion(".")); assertEquals("2.41.0", releaseManager.getIeDriverLatestVersion().getPrettyPrintVersion(".")); assertEquals("2.10.13.42", releaseManager.getChromeDriverLatestVersion().getPrettyPrintVersion(".")); + assertEquals("91.0.864.48", releaseManager.getMsEdgeDriverLatestVersion().getPrettyPrintVersion(".")); } @Test @@ -41,23 +43,26 @@ public void testGetVersionsFromLiveSource() throws Exception { String wdManifest = "http://selenium-release.storage.googleapis.com/"; String chromeManifest = "http://chromedriver.storage.googleapis.com/LATEST_RELEASE"; String marionetteManifest = "http://chromedriver.storage.googleapis.com/LATEST_RELEASE"; + String msEdgeManifest = "https://msedgedriver.azureedge.net/LATEST_STABLE"; WebDriverReleaseManager manager = - new WebDriverReleaseManager(new URL(wdManifest), new URL(chromeManifest), new URL(marionetteManifest)); + new WebDriverReleaseManager(new URL(wdManifest), new URL(chromeManifest), new URL(marionetteManifest), new URL(msEdgeManifest)); assertNotEquals(null, manager.getWedriverLatestVersion().getPrettyPrintVersion(".")); assertNotEquals(null, manager.getIeDriverLatestVersion().getPrettyPrintVersion(".")); assertNotEquals(null, manager.getChromeDriverLatestVersion().getPrettyPrintVersion(".")); + assertNotEquals(null, manager.getMsEdgeDriverLatestVersion().getPrettyPrintVersion(".")); assertEquals("selenium-server-standalone", manager.getWedriverLatestVersion().getName()); assertEquals("IEDriverServer", manager.getIeDriverLatestVersion().getName()); assertEquals("chromedriver", manager.getChromeDriverLatestVersion().getName()); + assertEquals("msedgedriver", manager.getMsEdgeDriverLatestVersion().getName()); assertNotEquals(null, manager.getWedriverLatestVersion().getRelativePath()); assertNotEquals(null, manager.getIeDriverLatestVersion().getRelativePath()); assertNotEquals(null, manager.getChromeDriverLatestVersion().getRelativePath()); - + assertNotEquals(null, manager.getMsEdgeDriverLatestVersion().getRelativePath()); } diff --git a/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/grid/GridStarterTest.java b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/grid/GridStarterTest.java index cb1dde01..a7407abc 100644 --- a/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/grid/GridStarterTest.java +++ b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/grid/GridStarterTest.java @@ -250,6 +250,18 @@ public void testChromeDriverDString() throws Exception { } } + @Test + public void testMsEdgeDriverDString() throws Exception { + Config config = new Config(); + if (RuntimeConfig.getOS().isWindows()) { + config.getMsEdgeDriver().setDirectory("\\tmp\\webdriver\\msedgedriver"); + assertTrue(GridStarter.getMsEdgeDriverExecutionPathParam(config).contains("-Dwebdriver.edge.driver=\\tmp\\webdriver\\msedgedriver\\msedgedriver_")); + } else { + config.getMsEdgeDriver().setDirectory("/tmp/webdriver/msedgedriver"); + assertTrue(GridStarter.getMsEdgeDriverExecutionPathParam(config).contains("-Dwebdriver.edge.driver=/tmp/webdriver/msedgedriver/msedgedriver_")); + } + } + private String readFile(String filePath) { String returnString = ""; diff --git a/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/tasks/DownloadMsEdgeDriverTest.java b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/tasks/DownloadMsEdgeDriverTest.java new file mode 100644 index 00000000..04032d9c --- /dev/null +++ b/SeleniumGridExtras/src/test/java/com/groupon/seleniumgridextras/tasks/DownloadMsEdgeDriverTest.java @@ -0,0 +1,195 @@ +/** + * Copyright (c) 2013, Groupon, Inc. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * + * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * Neither the name of GROUPON nor the names of its contributors may be + * used to endorse or promote products derived from this software without + * specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A + * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED + * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + * Created with IntelliJ IDEA. + * User: Dima Kovalenko (@dimacus) && Darko Marinov + * Date: 5/10/13 + * Time: 4:06 PM + */ + +package com.groupon.seleniumgridextras.tasks; + +import com.google.gson.Gson; + +import com.groupon.seleniumgridextras.config.Config; +import com.groupon.seleniumgridextras.config.DefaultConfig; +import com.groupon.seleniumgridextras.config.RuntimeConfig; +import com.groupon.seleniumgridextras.utilities.json.JsonParserWrapper; + +import org.junit.After; +import org.junit.Before; +import org.junit.Test; + +import java.io.File; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.Map; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertFalse; + +public class DownloadMsEdgeDriverTest { + + public DownloadMsEdgeDriver task; + private String downloadDir = "/tmp/msedge_downloader_test"; + + @Before + public void setUp() throws Exception { + deleteDownloadDir(); + RuntimeConfig.setConfigFile("download_msedge_test.json"); + Config config = DefaultConfig.getDefaultConfig(); + + config.getMsEdgeDriver().setDirectory(downloadDir); + + config.writeToDisk(RuntimeConfig.getConfigFile()); + + RuntimeConfig.load(); + task = new DownloadMsEdgeDriver(); + } + + @After + public void tearDown() throws Exception { + File config = new File(RuntimeConfig.getConfigFile()); + config.delete(); + new File(RuntimeConfig.getConfigFile() + ".example").delete(); + deleteDownloadDir(); + } + + @Test + public void testGetEndpoint() throws Exception { + assertEquals("/download_msedgedriver", task.getEndpoint()); + } + + @Test + public void testGetDescription() throws Exception { + assertEquals("Downloads a version of MsEdgeDriver to local machine", task.getDescription()); + } + + @Test + public void testGetJsonResponse() throws Exception { + assertEquals( + "{\"exit_code\":0,\"out\":[],\"error\":[],\"root_dir\":[\"" + downloadDir + + "\"],\"file\":[\"\"],\"file_full_path\":[\"" + + "\"],\"source_url\":[\"\"]}", + task.getJsonResponse().toString()); + } + + @Test + public void testGetAcceptedParams() throws Exception { + assertEquals("Version of MsEdgeDriver to download, such as 76.0.182.22", + task.getAcceptedParams().get("version").getAsString()); + + assertEquals("Bit Version of MsEdgeDriver 32/64 - (default: 32)", + task.getAcceptedParams().get("bit").getAsString()); + + assertEquals(2, task.getAcceptedParams().entrySet().size()); + } + + @Test + public void testExecute() throws Exception { + + String os = getOS(); + // default setting from configuration + String bit = "32"; + String version = "76.0.182.22"; + RuntimeConfig.getConfig().getMsEdgeDriver().setVersion(version); + + Map firstExec = JsonParserWrapper.toHashMap(task.execute(version)); + File expectedFile = new File(RuntimeConfig.getConfig().getMsEdgeDriver().getExecutablePath()); + + assertEquals(0.0, firstExec.get("exit_code")); + assertEquals(expectedFile.getName(), ((ArrayList) firstExec.get("file")).get(0)); + assertEquals(0, ((ArrayList) firstExec.get("error")).size()); + assertEquals(0, ((ArrayList) firstExec.get("out")).size()); + assertEquals(downloadDir, ((ArrayList) firstExec.get("root_dir")).get(0)); + assertEquals(expectedFile.getAbsolutePath(), + ((ArrayList) firstExec.get("file_full_path")).get(0)); + assertEquals("https://msedgedriver.azureedge.net/" + version + "/edgedriver_" + os + bit + ".zip", + ((ArrayList) firstExec.get("source_url")).get(0)); + + Map secondExec = JsonParserWrapper.toHashMap(task.execute(version)); + + assertEquals(0.0, secondExec.get("exit_code")); + assertEquals(0, ((ArrayList) secondExec.get("error")).size()); + assertEquals("File already downloaded, will not download again", + ((ArrayList) secondExec.get("out")).get(0)); + + assertFalse(secondExec.containsKey("root_dir")); + assertFalse(secondExec.containsKey("source_url")); + + assertEquals(expectedFile.getAbsolutePath(), + ((ArrayList) firstExec.get("file_full_path")).get(0)); + } + + @Test + public void testCustomExecute() throws Exception { + String os = getOS(); + String bit = "64"; + String version = "77.0.235.9"; + RuntimeConfig.getConfig().getMsEdgeDriver().setBit(bit); + RuntimeConfig.getConfig().getMsEdgeDriver().setVersion(version); + + DownloadMsEdgeDriver customSettingTask = new DownloadMsEdgeDriver(); + + Map firstExec = JsonParserWrapper.toHashMap(customSettingTask.execute(version)); + assertEquals("https://msedgedriver.azureedge.net/" + version + "/edgedriver_" + os + bit + ".zip", + ((ArrayList) firstExec.get("source_url")).get(0)); + + } + + private String getOS() { + if (RuntimeConfig.getOS().isWindows()) { + return "win"; + } else if (RuntimeConfig.getOS().isMac()) { + return "mac"; + } else { + return "linux"; + } + } + + private void deleteDownloadDir() { + + File dir = new File(downloadDir); + + if (dir.exists()) { + if (dir.list().length != 0) { + for (String file : dir.list()) { + new File(dir, file).delete(); + } + } + + dir.delete(); + + } + + } + +} diff --git a/SeleniumGridExtras/src/test/resources/fixtures/msedgedriver_release_version.txt b/SeleniumGridExtras/src/test/resources/fixtures/msedgedriver_release_version.txt new file mode 100644 index 00000000..3a931720 Binary files /dev/null and b/SeleniumGridExtras/src/test/resources/fixtures/msedgedriver_release_version.txt differ