Custom Attributes in WebSpy
Consider sample web application http://www.libraryinformationsystem.org/react-js
Let's see how the DOM node for the Password
input looks like in the Spy:
data:image/s3,"s3://crabby-images/3a881/3a881407fcb9c1b7f67cd545953c8d7d53cdcf8f" alt=""
It contains the placeholder
attribute. However XPath is built using the id
. Sometimes we want to use such an attribute for XPath generation and for Learn.
Open the Web Spy Settings.
data:image/s3,"s3://crabby-images/37697/37697d77a5b6f005b21bbfd99221703c7eb25e31" alt=""
data:image/s3,"s3://crabby-images/255e9/255e9f03e2802fcbf30de988f2e00e7ceae60896" alt=""
By default Include DOM Attributes is empty. This means two things:
1. Use all attributes in the Spy Tree.
2. Use default attributes (id
, name
, for
, label
) for the XPath generation (xpath_min
and xpath_index
).
Let's change it to placeholder,id
:
data:image/s3,"s3://crabby-images/4192c/4192c87d35f98a8e6047bbc6bc92d64f5ea05c9c" alt=""
Now get snapshot again (Ctrl+G
) and select the same element (Ctrl+T
).
data:image/s3,"s3://crabby-images/71f7a/71f7a0f153481d520c112ef8a0eae2b9c162e388" alt=""
We can see that XPath generator used the placeholder
attribute. Its logic is following:
- If XPath with
placeholder
is sufficient then only one attribute is used. - If there is no
placeholder
then id
attribute is used by XPath generator (since we specified placeholder,id
as a filter). - If there is
placeholder
, but it does not produce unique XPath and there is also an id
then both placeholder
and id
are used. - If no XPath is produced that way, then
xpath_full
(having no attributes but full path) is used.
If you want to use custom attributes for the Learn, then you may specify xpath_min
as a default XPath:
data:image/s3,"s3://crabby-images/809e9/809e9666ccfab43e043c2322357847addebd16fc" alt=""
DOM Attribute Include Filter specified in the options dialog is persistent. So you may fine-tune it for the specific application once and then get optimized XPath expressions every time when using Rapise Web Spy.