Handling Shadow DOM in Selenium
If there is a shadow element in the webpage we cannot interact directly with selenium code, normally if we locate the element by finding the Element method then it will throw NosuchElement Exception in order to overcome this situation please read the below-mentioned context.
How to Identify Shadow DOM Exists?
The shadow DOM can identify by a shadow root XPath that is enclosed somewhere in the middle of the HTML structure.
Section: #shadow-root (open) is implemented before the start of every Shadow DOM.
In HTML there can be multiple shadow root sections each section’s shadow properties are completely hidden from the actual Main DOM.
So, we cannot access the shadow elements directly from Main DOM
Handling Shadow DOM Elements
There are two ways to handle/locate shadow elements in selenium by
- Using JavaScript Executor
- Shadow Libraries by Maven dependency
1) Using JavaScript Executor
Using the JavaScript Executor interface we can execute shadow DOM query scripts in our selenium code by the executeScript method.
SYNTAX:
Read Also:- Process Java Script Executor in Selenium Test Automation
Here we are downcasting Javascript Executor with driver reference in order to make the executeScript method available to the current driver reference.
Test Scenario: Automate Clear data function in Chrome browser
- Open the Chrome browser
- Maximize the browser window
- Navigate to the chrome settings page
- Click on Privacy and security
- Click on Clear browsing data
- Click on clear data
Create a class with the name HandleShadowDomByJavascript and paste the below code
Read Also:- Mobile Test Automation Using Appium Python
2) Shadow Libraries by Maven Dependency
We can access shadow libraries by adding the Maven dependency in our pom.xml file
From the above code, the chrome browser opens with a maximized window to navigate to the chrome settings page and it performs clear data actions with the help of Javascript Executor/Shadow Libraries in our test automation script.
FAQ’s
1) Why Are Some Elements Not Accessible With Selenium?
There are a few reasons why some elements may not be accessible with Selenium. The first reason is that the element may be located in a shadow DOM. Shadow DOM is a type of document object model where elements render in a separate tree from the main document. This means that they are not visible to Selenium unless you know how to access them. The second reason is that the element may be dynamically generated, which means it is not present in the HTML source code.
2) Are There Any Drawbacks To Using The Shadow DOM?
First, it’s currently only available as an experimental feature in Firefox. That’s why if you plan on writing code to work with any other browsers besides Firefox, then the shadow DOM selenium may not be appropriate for your project.
Second, since it’s still experimental and not yet widely adopted by browser vendors, there are some rendering differences between browsers that could affect your design if you use CSS selectors or JavaScript APIs specific to the shadow DOM.
If you are interested in even more software testing-related articles and information from us here at Devstringx, then we have a lot to choose from.
Original Source:- Click Here
Comments
Post a Comment