Feature
The Feature attribute stores, roughly said, a text that is useful for recognition and is directly connected to the component itself. This can be either the text of the component (for example the label on a button), a programmatically assigned identifier or label of a component (for example CheckBox, RadioButton, TextField), a title (Window, 'Dialog', 'TitledPanel'), or for a Web page the URL.
Frequently, the value of the Feature is identical to the Extra feature qfs:label
.
This is because the label of the component is stored in qfs:label
and this is often the text that is directly connected to the component.
The redundancy still makes sense, since a status can be set for the extra feature:
'Ignore', 'Should match', or 'Must match'.
The Feature implicitly always has the status 'Should match'.
For backwards compatibility reasons it cannot be replaced by qfs:label
.
If no Name can be determined, the Feature is used for generating the QF-Test component ID. Examples for this can be found in How to judge robust component recognition.
Components can also be addressed directly in a SmartID via the Feature without recording a Component node.
Using regular expressions for working with dynamic window titles
The Video 'Component
recognition' shows the use of regular expressions with window titles starting from minute
13:07.
In a lot of applications the developers do not use unique names and QF-Test keeps recording the same components again and again in different places. Playback with previously recorded components may still work, unless the window geometry changes significantly.
In this case it is very likely that the title of the main window changes frequently, for example to display a version string, a user name, a file name or some other variable information. If you want to keep your tests working and prevent recording multiple variants of this window and all its components, you have to select the respective Window node and edit its Feature attribute to replace the dynamic parts of the title with a regular expression. Be sure to check 'Use regexp'. Now your tests should work again.
Here you can see the use of a regular expression for a component of the CarConfigurator. Its Feature attribute has to start with 'Edit' followed by an optional dynamic part:
data:image/s3,"s3://crabby-images/3b9a4/3b9a49fe7b358eebbdaeebfea15151e7cd35b5d6" alt=""
QF-Test uses regular expressions in many places. You can find detailed information in section 49.3 to learn more about how to use them.
Feature for web components
For web components, the Feature is determined according to the following logic:
-
HTML elements of class
Frame
orDocument
use the URL as Feature attribute. -
If none of the following special cases apply, the
id
attribute of the HTML element is used, if it exists and is sufficiently unique. Otherwise, the inner text of the HTML element, truncated if necessary, is used as Feature attribute. - Special cases:
HTML tag name | Value of the Feature attribute |
---|---|
TEXT | Text of the HTML element, truncated if necessary |
A | Text of the HTML element (truncated if necessary), otherwise the window title or the URL |
FIELDSET | Text of a contained HTML element with tag name "LEGEND" |
FORM | Value of the "name" attribute |
IMG | Value of the "alt" attribute, otherwise "src", otherwise part of the URL |
INPUT | Value of the "name" attribute. For radio buttons with identical names, the value of the attribute "name" with the value of the "value" attribute appended |
BUTTON | Value of the "name" attribute, otherwise text of the HTML element, truncated if necessary |
LABEL | Text of the HTML element, truncated if necessary |
SELECT | Value of the "name" attribute |
OPTION | If the option OPT_WEB_USE_OPTION_LABEL is set,
value of the "label" attribute, otherwise the text of the HTML element, truncated if necessary |
OPTGROUP | Value of the "label" attribute |
IFRAME | Value of the "id" attribute, otherwise "name", otherwise "src" |
In rare special cases, the Feature attribute may also receive a value which is not described by the logic above.