-
Notifications
You must be signed in to change notification settings - Fork 99
Heuristic Used by Browser Test
The standard behavior of BrowserTest is to use a heuristic to find the element on a web page based on the (end-user) description in the wiki. This heuristic involves checking multiple possible meanings of the description and using the first element matching the description. First it tries to find an exact match. If no exact match can be found, the same steps are re-tried to see whether a partial match can be found. When the heuristic does not suffice to find the element one needs, the heuristic may be bypassed in favor of technical selectors (e.g. by id, xpath or css) to specify which element is meant.
The heuristic is based on what command the element is needed for. The options considered (and their order) are listed below.
- Label's text (either a contained input/textarea or the element identified by the 'for' attribute)
- Input's placeholder
- Value attribute of (visible) input
- Textarea's placeholder
- Input of type 'checkbox', if place is 'checkbox'
- Table header (th) text in row
- Term/name in a description list ('dt' element)
- Aria-label (either 'aria-label' attribute value or the text of an element identified by an 'aria-labelledby' attribute)
- Element's title (i.e. tooltip text)
- Link's text
- Button's text
- Each option listed above for 'Enter/Retrieve Value'
- Input with type 'reset' or 'submit', if place is 'Submit' or 'Reset'
- Text of element with an 'onclick' attribute
- Element's text
Same as for 'Click'
- Link's text
- Aria-label (either 'aria-label' attribute value or the text of an element identified by an 'aria-labelledby' attribute)
- Element's title (i.e. tooltip text)
- Legend's text to select fieldset
- Aria-label (either 'aria-label' attribute value or the text of an element identified by an 'aria-labelledby' attribute)
It is possible to extend the heuristics used by BrowserTest. For this, you need to extend BrowserTest and override one of the following methods:
- getElementToClick()
- getElementToCheckVisibility()
- getElementToSendValue()
- getElementToSelectFor()
- getElementToRetrieveValue()
- getContainerElement()
@Override
protected WebElement getContainerElement(String container) {
return firstNonNull(
() -> findElement(By.id(container)),
() -> super.getContainerElement(container));
}
@Override
protected WebElement getElementToRetrieveValue(String place, String container) {
return doInContainer(container,
() -> firstNonNull(
() -> getElementInRow(place),
() -> super.getElementToRetrieveValue(place, null)));
}
private getElementInRow(String place) {
return findByXPath(
".//div[@class='row']/div/text()[contains(normalized(.),'%s:')]/../../div[2]",
place)
}