Instructions for Java and Selenium
Configuring your tests with Java and Selenium
-
Add a new dependency for the Java Watcher package to your
pom.xml(for Maven) dependencies section (the Java Watcher package is available on Maven Central):<dependencies> <!-- Add this dependency: --> <dependency> <groupId>com.deque.axe_core</groupId> <artifactId>watcher</artifactId> <version>3.23.0</version> <!-- Update this as needed --> </dependency> </dependencies> -
Add imports for Java Watcher to your testing code:
import com.deque.axe_core.commons.AxeWatcherOptions; import com.deque.axe_core.selenium.AxeWatcher; import com.deque.axe_core.selenium.AxeWatcherDriver; -
Add setup code for Java Watcher, including your personal API key and project ID (both stored in the environment for security and flexibility):
AxeWatcherOptions options = new AxeWatcherOptions() .setApiKey(System.getenv("ACCESSIBILITY_API_KEY")) .setProjectId(System.getenv("PROJECT_ID")); AxeWatcher watcher = new AxeWatcher(options); ChromeOptions chromeOptions = new ChromeOptions(); chromeOptions = watcher.configure(chromeOptions); WebDriver wrappedDriver = watcher.wrapDriver(new ChromeDriver(chromeOptions));This code snippet creates a new
WebDriverinstance calledwrappedDriverthat you need to cast to use the axe controller methods.Be sure to set
ACCESSIBILITY_API_KEYandPROJECT_IDin your environment to your personal API key (found in your axe Account, API KEYS tab) and your project ID (shown at the top of these instructions when you created your project or available from the Projects page by choosing Configure project under Settings). -
At the end of your testing session, call
flush():((AxeWatcherDriver) wrappedDriver).axeWatcher().flush();Calling
flush()indicates that the test run is finished, and the results can be processed and presented to the user.
