com.seleniumtests.util.osutility.OSUtility Maven / Gradle / Ivy
/**
* Orignal work: Copyright 2015 www.seleniumtests.com
* Modified work: Copyright 2016 www.infotel.com
* Copyright 2017-2019 B.Hecquet
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.seleniumtests.util.osutility;
import java.io.IOException;
import java.nio.charset.Charset;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.lang3.SystemUtils;
import org.apache.logging.log4j.Logger;
import org.openqa.selenium.Platform;
import org.openqa.selenium.Proxy;
import com.seleniumtests.browserfactory.BrowserInfo;
import com.seleniumtests.customexception.ConfigurationException;
import com.seleniumtests.driver.BrowserType;
import com.seleniumtests.util.logging.SeleniumRobotLogger;
/**
* Facade of the OS Utility Windows or Unix
*/
public abstract class OSUtility {
protected static final Logger logger = SeleniumRobotLogger.getLogger(OSUtility.class);
protected static final String LATEST_VERSION = "latest";
private String[] webBrowserProcessList = {"chrome", "firefox", "iexplore", "safari", "msedge"};
private String[] webDriverProcessList = {"chromedriver", "geckodriver", "iedriverserver", "microsoftwebdriver", "edgedriver"};
private static Map> installedBrowsersWithVersion;
private static Charset consoleCharset = null;
/******************************************
*********** OS information ***************
******************************************/
/**
* Platform on which this test executes
* @return
*/
public static Platform getCurrentPlatorm() {
if (isWindows()) {
return Platform.WINDOWS;
} else if (isLinux()) {
return Platform.LINUX;
} else if (isMac()) {
return Platform.MAC;
} else {
throw new ConfigurationException(getOSName() + " is not recognized as a valid platform");
}
}
/**
* @return the name of the Operating System
*/
public static String getOSName() {
return System.getProperty("os.name");
}
/**
* @return true if the OS is Windows
*/
public static boolean isWindows() {
return getOSName().startsWith("Win");
}
/**
* Used to simplify mocking
* @return
*/
public static boolean isWindows10() {
return SystemUtils.IS_OS_WINDOWS_10;
}
/**
* @return true if the OS is Windows
*/
public static boolean isLinux() {
return getOSName().startsWith("Linux");
}
/**
* @return true if the Operating System is MAC OS X
*/
public static boolean isMac() {
return getOSName().startsWith("Mac");
}
/**
* @return operating system JVM architecture
*/
public static String getArchitecture() {
return System.getProperty("os.arch");
}
/**
*
* @return the quantity of bits of the processor
*/
public static String getOSBits() {
return System.getProperty("sun.arch.data.model");
}
/******************************************
********** Process information ***********
******************************************/
/**
* Returns list of all running processes
* @return
*/
public abstract List getRunningProcessList();
/**
* get sub process of parent one
* @param parentProcess the parent process
* @param processName the process name to search. May be null if any child should be matched
* @param existingPids reply will not contain these PIDs
* @return
* @throws IOException
*/
public abstract List getChildProcessPid(Long parentProcess, String processName, List existingPids) throws IOException;
/**
* @param name of the process
* @return ProcessInfo
*/
public ProcessInfo getRunningProcess(String processName) {
try {
return getRunningProcesses(processName).get(0);
} catch (IndexOutOfBoundsException e) {
return null;
}
}
/**
* @param name of the process
* @return ProcessInfo
*/
public List getRunningProcesses(String processName) {
List processes = new ArrayList<>();
for (ProcessInfo processInfo : getRunningProcessList()) {
if (processInfo.getName().equalsIgnoreCase(processName)){
processes.add(processInfo);
}
}
return processes;
}
/**
* @param processName : process name
* @return true if the key is found in the running process list.
*/
public boolean isProcessRunning(String processName) {
ProcessInfo processInfo = getRunningProcess(processName);
return (processInfo != null && processInfo.getName() != null);
}
/**
* @param pid : pId of the process
* @return true if the key is found in the running process list.
*/
public boolean isProcessRunningByPid(String pid) {
for (ProcessInfo processInfo : getRunningProcessList()) {
if (pid.equals(processInfo.getPid())){
return true;
}
}
return false;
}
/**
* @param pid : pId of the process
* @return true if the key is found in the running process list.
*/
public ProcessInfo getProcessRunningByPid(String pid) {
for (ProcessInfo processInfo : getRunningProcessList()) {
if (pid.equals(processInfo.getPid())){
return processInfo;
}
}
return null;
}
/**
* @param showAll running process found
* @return true if one of the running process is a known web browser.
*/
public boolean isWebBrowserRunning(boolean showAll) {
return !whichWebBrowserRunning().isEmpty();
}
/**
* @return the list of the running known web browser processes.
*/
public List whichWebBrowserRunning() {
return whichWebBrowserRunning(false);
}
/**
* @return the list of the running known web browser processes.
* @param showAll running process found
*/
public List whichWebBrowserRunning(boolean showAll) {
List webBrowserRunningList = new ArrayList<>();
for (ProcessInfo processInfo : getRunningProcessList()) {
for (String processName : webBrowserProcessList){
if (processInfo.getName().equalsIgnoreCase(processName)) {
if (showAll) {
logger.info("Web browser process still running : " + processInfo.getName());
}
webBrowserRunningList.add(processInfo);
}
}
}
return webBrowserRunningList;
}
/******************************************
************* KILL process ***************
******************************************/
/**
* Kill process by PID
* @param process
* @param force
* @throws IOException
*/
public abstract String killProcess(String pid, boolean force);
/**
* Kill process by name
* @param process
* @param force
* @throws IOException
*/
public abstract String killProcessByName(String programName, boolean force);
/**
* Get extension of the program
* @return
*/
public abstract String getProgramExtension();
/**
* Returns the charset for the console
* @return
*/
public abstract Charset getConsoleCharset();
/**
* Returns the process that listens for the given port, or null if none is found
* @param port
*/
public abstract Integer getProcessIdByListeningPort(int port);
/**
* Ask system to terminate all the known web browser processes.
* @param force
*/
public void killAllWebBrowserProcess(boolean force){
List browserProcesses = whichWebBrowserRunning(false);
for (ProcessInfo processInfo : browserProcesses) {
logger.info("Asked system to terminate browser: " + processInfo.getName());
killProcess(processInfo.getPid(), force);
}
}
/**
* Ask system to terminate all the drivers processes
* @param force
*/
public void killAllWebDriverProcess(){
for (ProcessInfo processInfo : getRunningProcessList()) {
for (String processName : webDriverProcessList) {
if (processInfo.getName().contains(processName)){
logger.info("Asked system to terminate webdriver: " + processInfo.getName());
killProcess(processInfo.getPid(), true);
}
}
}
}
public abstract int getIEVersion();
public abstract String getOSBuild();
public abstract String getProgramNameFromPid(Long pid);
public static Charset getCharset() {
if (consoleCharset == null) {
consoleCharset = OSUtilityFactory.getInstance().getConsoleCharset();
}
return consoleCharset;
}
/**
* Returns the full version of chrome browser
* String is like "Google Chrome X.Y.Z.T"
* @param chromePath
* @return
*/
public static String getChromeVersion(String chromePath) {
OSUtility osUtility = OSUtilityFactory.getInstance();
if (osUtility instanceof OSUtilityWindows) {
return "Google Chrome " + ((OSUtilityWindows)osUtility).getChromeVersionFromFolder(chromePath);
} else {
return OSCommand.executeCommandAndWait(new String[] {chromePath, "--version"});
}
}
/**
* Returns the full version for firefox browser
* @param firefoxPath
* @return
*/
public static String getFirefoxVersion(String firefoxPath) {
return OSCommand.executeCommandAndWait(firefoxPath + " --version | more");
}
public List getInstalledBrowsers() {
List browsers = new ArrayList<>();
Map> installedBrowsers = getInstalledBrowsersWithVersion();
for (Entry> bTypeEntry: installedBrowsers.entrySet()) {
if (!bTypeEntry.getValue().isEmpty()) {
browsers.add(bTypeEntry.getKey());
}
}
return browsers;
}
/**
* Returns the list of browsers for each type. For selenium robot local, this will help selecting the right binary
* For grid, we will be able to provide each installed browser to the runner
* @return
*/
public abstract Map> discoverInstalledBrowsersWithVersion(boolean discoverBetaBrowsers);
public Map> discoverInstalledBrowsersWithVersion() {
return discoverInstalledBrowsersWithVersion(false);
}
/**
* example: Mozilla Firefox 52.0
* @param versionString
* @return
*/
public static String extractFirefoxVersion(String versionString) {
Pattern regMozilla = Pattern.compile("^Mozilla .* (\\d+\\.\\d+).*");
Matcher versionMatcher = regMozilla.matcher(versionString.trim());
if (versionMatcher.matches()) {
return versionMatcher.group(1);
} else {
return "";
}
}
/**
* example: Google Chrome 57.0.2987.110
* @param versionString
* @return
*/
public static String extractChromeVersion(String versionString) {
Pattern regChrome = Pattern.compile("^Google Chrome (\\d+\\.\\d+).*");
Matcher versionMatcher = regChrome.matcher(versionString.trim());
if (versionMatcher.matches()) {
return versionMatcher.group(1);
} else {
return "";
}
}
/**
* Returns the version . either with chrome or chromium
* @param versionString
* @return
*/
public static String extractChromeOrChromiumVersion(String versionString) {
if (versionString.contains("Chromium")) {
return extractChromiumVersion(versionString);
} else {
return extractChromeVersion(versionString);
}
}
/**
* example: Chromium 56.0.2924.76 Built on Ubuntu , running on Ubuntu 16.04
* @param versionString
* @return
*/
public static String extractChromiumVersion(String versionString) {
Pattern regChrome = Pattern.compile("^Chromium (\\d+\\.\\d+).*");
Matcher versionMatcher = regChrome.matcher(versionString.trim());
if (versionMatcher.matches()) {
return versionMatcher.group(1);
} else {
return "";
}
}
/**
* example: 11.0.9600.18499
* @param versionString
* @return
*/
public static String extractIEVersion(String versionString) {
return versionString.split("\\.")[0];
}
/**
* example: 10240.th1.160802-1852
* @param versionString
* @return
*/
public static String extractEdgeVersion(String versionString) {
Pattern regEdge = Pattern.compile("^(\\d+\\.\\d+).*");
Matcher versionMatcher = regEdge.matcher(versionString.trim());
if (versionMatcher.matches()) {
return versionMatcher.group(1);
} else {
return "";
}
}
/**
* Clear list of browsers to return it null
* @return
*/
public static void resetInstalledBrowsersWithVersion() {
installedBrowsersWithVersion = null;
}
/**
* Returns a map of browser, by type. It won't search for Beta browsers
* @return
*/
public static Map> getInstalledBrowsersWithVersion() {
return getInstalledBrowsersWithVersion(false);
}
/**
* Returns a map of browser, by type
* @param discoverBetaBrowsers if true, also beta browsers will be searched (for now, chrome only)
* @return
*/
public static Map> getInstalledBrowsersWithVersion(boolean discoverBetaBrowsers) {
if (installedBrowsersWithVersion == null) {
refreshBrowserList(discoverBetaBrowsers);
}
return installedBrowsersWithVersion;
}
/**
* search browsers
*/
public static void refreshBrowserList() {
refreshBrowserList(false);
}
public static void refreshBrowserList(boolean discoverBetaBrowsers) {
installedBrowsersWithVersion = OSUtilityFactory.getInstance().discoverInstalledBrowsersWithVersion(discoverBetaBrowsers);
}
/**
* Sets the proxy at system level
* @param proxy
*/
public abstract void setSystemProxy(Proxy proxy);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy