Version 8.0.2 |
The previously described approach will work for most standard components as buttons or checkboxes. But besides those components there are also complex components in our GUI. Those components represent data, and we would like to address their content by the sub-item syntax provided by QF-Test. Those components could be tables, trees or lists. For those components we need to map the dedicated class as well as the sub-item class. You will find the details in the following sections: 'CustomWebResolver' – Combo boxes, 'CustomWebResolver' – Lists, 'CustomWebResolver' – Tables, 'CustomWebResolver' – TabPanel and Accordion, 'CustomWebResolver' – Tree.
| |||||||
Figure 50.15: Simplification for complex components |
Our example is the table showing the cars of the "CarConfigurator Web". Again, we need to record some clicks on the shown cars and analyze the recording. The standard recording looks like this:
Figure 50.16: Recording of a table in "CarConfigurator Web" |
The click was recorded on a TD
component, which
is the child of a TR
component, which is part of a
TABLE
component. The recorded
TD
component contains an extra feature
class
with the value dataCell
. The
TR
component has the value dataRow
,
and the TABLE
has the value dataTable
for that attribute.
When we select the nodes and observe the component highlighting in the SUT we notice the following:
A TD
node represents a cell, a
TR
node represents a row of a table and a
TABLE
node represents an entire table. Exactly those
nodes need to be investigated now in order to create a good
mapping to generic classes. QF-Test requires those three classes
plus the header row and a header cell to resolve a table, see
'CustomWebResolver' – Tables for details.
Let's start with the TABLE
node. This node has a
class
attribute with the value
dataTable
. This seems to be a clear sign that any
dataTable
represents a table. So we select the
'Install CustomWebResolver' node again
and extend the category genericClasses
by
Table: dataTable
.
The next step is the row of the table. After selecting the
TR
node we can see that there is another
class
attribute with the value
dataRow
. This seems to be a clean-cut case.
Now we need to add that value to the
'Install CustomWebResolver' node again
and extend the category genericClasses
with
TableRow: dataRow
.
Next we need to analyze the TD
node.
Again, we find the class
attribute, this time
with the value dataCell
. So, let's add this to our
node as before: Add TableCell: dataCell
to genericClasses
.
Also, we would like QF-Test to recognize the column headers, so it can
use them as text index for the column when we record a table cell.
This time the class
attribute is
headerRow
for the header row and headerCell
for each column header. So we complete the
genericClasses
category. It now reads:
| ||||
Example 50.33: Category genericClasses |
We will now delete the previously recorded components, run the 'Install CustomWebResolver' node, re-load the web page and re-record a click again.
As result we get a click with the typical QF-Test item syntax on a
component like VehicleTable@Model&0
(or any other
row, depending what you clicked on). In the recorded
components area you will just see the Table
object and no
child component anymore
as they are now treated by QF-Test as items of a table.
Figure 50.17: Recording of resolved table item in "CarConfigurator Web" |
After resolving this complex component we can proceed to the next section for the next steps.
Last update: 12/4/2024 Copyright © 1999-2024 Quality First Software GmbH |