Skip to content

Automatic Selenium Webdriver binaries management in runtime for Java

License

Notifications You must be signed in to change notification settings

hallooyo/webdrivermanager

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

61 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

WebDriverManager

This piece of software is a small library aimed to automate the Selenium Webdriver binaries management within a Java project in runtime.

If you have ever used Selenium Webdriver, you probably know that in order to use some browsers (for example Chrome, Internet Explorer, or Opera) you need to download a binary which allows WebDriver to handle the browser. In addition, the absolute path to this binary must be set as Java variables, as follows:

System.setProperty("webdriver.chrome.driver", "/absolute/path/to/binary/chromedriver");
System.setProperty("webdriver.opera.driver", "/absolute/path/to/binary/operadriver");
System.setProperty("webdriver.ie.driver", "C:/absolute/path/to/binary/IEDriverServer.exe");

This is quite annoying since it forces you to link directly this binary in your source code. In addition, you have to check manually when new versions of the binaries are released. This library comes to the rescue, performing in an automated way all this dirty job for you.

WebDriverManager is open source, released under the terms of LGPL License.

Usage

In order to use WebDriverManager in a Maven project, first add the following dependency to your pom.xml:

<dependency>
	<groupId>io.github.bonigarcia</groupId>
	<artifactId>webdrivermanager</artifactId>
	<version>1.2.2</version>
</dependency>

Then you can let WebDriverManager to do manage WebDriver binaries for your application/test. Take a look to this JUnit example which uses Chrome with Selenium WebDriver:

public class ChromeTest {

	protected WebDriver driver;

	@BeforeClass
	public void setupClass() {
		ChromeDriverManager.getInstance().setup();
	}

	@Before
	public void setupTest() {
		driver = new ChromeDriver();
	}

	@After
	public void teardown() {
		driver.quit();
	}

	@Test
	public void test() {
		// Using Selenium WebDriver to carry out automated web testing
	}

}

Notice that simple adding ChromeDriverManager.getInstance().setup(); WebDriverManager does magic for you:

  1. It checks the latest version of the WebDriver binary file
  2. It downloads the binary WebDriver if it is not present in your system
  3. It exports the required Java variable by Selenium WebDriver

So far, WebDriverManager supports Chrome, Opera, and Internet Explorer, as follows:

ChromeDriverManager.getInstance().setup();
InternetExplorerDriverManager.getInstance().setup();
OperaDriverManager.getInstance().setup();

Advanced

Configuration parameters for WebDriverManager are set in the application.properties file:

wdm.targetPath=~/.m2/repository/webdriver
wdm.override=false

wdm.chromeDriverUrl=http://chromedriver.storage.googleapis.com/
wdm.chromeDriverExport=webdriver.chrome.driver
wdm.chromeDriverVersion=LATEST

wdm.operaDriverUrl=https://api.github.com/repos/operasoftware/operachromiumdriver/releases
wdm.operaDriverExport=webdriver.opera.driver
wdm.operaDriverVersion=LATEST

wdm.internetExplorerDriverUrl=http://selenium-release.storage.googleapis.com/
wdm.internetExplorerExport=webdriver.ie.driver
wdm.internetExplorerVersion=LATEST

The variable wdm.targetPath is the default folder in which WebDriver binaries are going to be stored. Notice that by default the path of the Maven local repository is used. The URLs to check the latest version of Chrome, Opera, and Internet Explorer are set using the variables wdm.chromeDriverUrl, wdm.operaDriverExport, and wdm.operaDriverUrl.

This properties can be overwritten with Java system properties. For example:

System.setProperty("wdm.targetPath", "/my/custom/path/to/driver/binaries");

... or by command line, for example:

-Dwdm.override=true

In addition, the usage of a architecture (32 or 64 bits) can be forced. By default, the suitable binary version for your system and architecture is downloaded and used. The architecture can be forced as follows:

new ChromeDriverManager().setup(Architecture.x32);
new ChromeDriverManager().setup(Architecture.x64);

new InternetExplorerDriverManager().setup(Architecture.x32);
new InternetExplorerDriverManager().setup(Architecture.x64);

new OperaDriverManager().setup(Architecture.x32);
new OperaDriverManager().setup(Architecture.x64);

By default, WebDriverManager downloads the latest version of the WebDriver binary. A concrete version of the WebDriver binary can be forced. For example, in order to use the version 2.17 of chromedriver, the version 2.46 of IEDriverServer, and the version 0.2.0 of operadriver respectively, you need to use WebDriverManager as follows:

new ChromeDriverManager().setup("2.17");

new InternetExplorerDriverManager().setup("2.46");

new OperaDriverManager().setup("0.2.0");

This can also be done by changing the value of the variables wdm.chromeDriverVersion, wdm.operaDriverVersion, or wdm.internetExplorerVersion, from its default value (LATEST) to a concrete version. For instance:

-Dwdm.chromeDriverVersion=2.17
-Dwdm.internetExplorerVersion=2.46
-Dwdm.operaDriverVersion=0.2.0

About

WebDriverManager (Copyright © 2015) is a personal project of Boni Garcia licensed under LGPL License. Comments, questions and suggestions are always very welcome!

About

Automatic Selenium Webdriver binaries management in runtime for Java

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 100.0%