DevTools-Selenium is a Java library for Integrating Selenium WebDriver and Chrome DevTools.
Declarative: DevTools-Selenium makes it painless to call devtools api either independently or through Selenium WebDriver. DevTools-Selenium will efficiently interact with Chrome DevTools Protocol, that allows for tools to instrument, inspect, debug and profile Chromium, Chrome, Edge and other Blink-based browsers.Declarative code make your test script more predictable, simpler to understand, and easier to debug.
Domain-Based: Build encapsulated components that assist to call each instrumentation domain like DOM, Debugger, Network etc. Every domain wrapper has all the commands it supports and events it generates.
Learn Once, Run Independently or with Selenium: We don't make assumptions about your test automation stack, so you can integrate the Devtools Features with Selenium WebDriver with single line of code. DevTools-Selenium also offer you to interact with Chrome through devtools API and without using Selenium WebDriver.
For more information on Chrome DevTools, see https://chromedevtools.github.io/devtools-protocol/. Selenium 4 Devtools API can be found here: https://github.com/SeleniumHQ/selenium/tree/master/java/client/src/org/openqa/selenium/support/devtools
The source code is made available under the [Apache 2.0 license]
Why should use this project?
- This is independent Java project that helps you to interact with chrome (with and without Selenium WebDriver) and perform all your devtools operations that is built within the chrome devtools protocol.
- For every single domain, the Java client is built and by which, the methods, types and event listeners are wrapped and exposed. By which, the integration becomes easier
Add the following dependency to your pom.xml
:
<dependency>
<groupId>com.qeagle</groupId>
<artifactId>DevTools-Selenium</artifactId>
<version>1.2.1</version>
</dependency>
Examples:
** Example of using Event Listeners - Waiting for the Layers to disappear **
/**
* Wait for the top layer to disappear - works for any loader
*
* @author Gopinath
*/
public class WaitForLayersToDisapper {
public static void main(String[] args) {
// Create chrome launcher.
System.setProperty("webdriver.chrome.driver", "./drivers/chromedriver.exe");
// Launch chrome using Selenium
ChromeDriver driver = new ChromeDriver();
// Get the Devtools Service
ChromeDevToolsService devToolsService = DevToolsService.getDevToolsService(driver);
// Load the URL now
driver.get("https://raphaelfabeni.com/css-loader/");
// Get the Layers
LayerTree layers = LayerChange.enableLayers(devToolsService);
// Click on loader
driver.findElement(By.id("loader-border")).click();
// Wait for the layers for reset
LayerChange.waitUntilLayerChanged(layers);
// Reset the layers
LayerChange.disableLayers(devToolsService);
// Click on the next element
driver.findElement(By.id("loader-bar-rounded")).click();
}
}
** Example of using Event Listeners - Performance Metrics **
/**
* Get the Performance metrics on every page load
*
* @author Gopinath
*/
public class PerformanceMetricsExample {
public static void main(String[] args) throws InterruptedException {
// Create chrome launcher.
System.setProperty("webdriver.chrome.driver", "./drivers/chromedriver.exe");
// Launch chrome using Selenium
ChromeDriver driver = new ChromeDriver();
// Get the Devtools Service
ChromeDevToolsService devToolsService = DevToolsService.getDevToolsService(driver);
// Measure Performance
NetworkPerformance.getPerformanceMetrics(devToolsService);
// Load Page
driver.get("https://selenium.dev/");
}
}
DevTools-Selenium Code for taking Full Page Screenshot
/**
* Takes a full page screenshot. The output screenshot dimensions will be page width x page height
*
*
* @author Gopinath
*/
public class FullPageScreenshot {
public static void main(String[] args) {
// Create chrome launcher.
System.setProperty("webdriver.chrome.driver", "./drivers/chromedriver.exe");
// Launch chrome using Selenium
ChromeDriver driver = new ChromeDriver();
driver.get("https://www.amazon.in/ref=cs_503_link/");
// Get the Devtools Service
ChromeDevToolsService devToolsService = DevToolsService.getDevToolsService(driver);
// Take full screen
FullScreenshot.captureFullPageScreenshot(devToolsService, "screenshot.png");
// Close the browser
driver.close();
}
}
DevTools Indepdent Code for taking Full Page Screenshot (Without Using Selenium)
/**
* Takes a full page screenshot for the browser launched usng CDP
*
* @author TestLeaf
*/
public class FullPageScreenshotWithoutSelenium {
public static void main(String[] args) {
// Create chrome launcher.
ChromeLauncher launcher = new ChromeLauncher();
// Launch chrome either as headless (true) or regular (false).
ChromeService chromeService = launcher.launch(false);
// Create empty tab ie about:blank.
ChromeTab tab = chromeService.createTab();
// Get DevTools service to this tab
ChromeDevToolsService devToolsService = chromeService.createDevToolsService(tab);
// Take full screen (Integrated with Selenium using Remote Debugger Address
FullScreenshot.captureFullPageScreenshot(devToolsService, "screenshot.png");
}
}
Selenium 4 Devtools Code for Taking Full Screenshot
public class SeleniumDevToolsFullSnap{
public static void main(String[] args) throws InterruptedException, IOException {
System.setProperty("webdriver.chrome.driver", "./drivers/chromedriver.exe");
ChromeOptions options = new ChromeOptions();
ChromeDriver driver = new ChromeDriver(options);
driver.manage().timeouts().implicitlyWait(30, TimeUnit.SECONDS);
DevTools devTools = driver.getDevTools();
devTools.createSession();
driver.get("https://www.amazon.com/");
driver.manage().window().maximize();
devTools.send(new Command(
"Emulation.setDeviceMetricsOverride",
ImmutableMap.of("deviceScaleFactor", 1,"mobile", false,"width",1400,"height",2000)));
String snap = devTools.send(new Command<>("Page.captureScreenshot",
ImmutableMap.of("fromSurface", true), ConverterFunctions.map("data", String.class)));
System.out.println(snap);
Base64 decoder = new Base64();
byte[] imgBytes = decoder.decode(snap.toString());
FileOutputStream osf = new FileOutputStream(new File("./snap1.png"));
osf.write(imgBytes);
osf.flush();
osf.close();
}
}
More Examples can be seen here.
Credit
Kenan Klisura (Chrome DevTools Project)
Additional Insights
- Selenium WebDriver Devtools is in the early stage of wrapping few essential domains. Hence you may have to write your own custom code for non available methods and listeners like above case.
- Whereas, in this repo - we have built all the existing chrome devtools domain - including methods, types and listeners in Java and that makes your code more manageable and simplified.
- This can be independently executed without Selenium WebDriver as well can be integrated with the chrome, which is launched by WebDriver. This provides flexibility for you to choose either one.
License Devtools - Selenium Java Client is licensed under the Apache License, Version 2.0.