public enum LocatorStrategy extends java.lang.Enum<LocatorStrategy> implements ValueEnum
In order to
make these identifiers as robust as possible across minor changes to an application, (such as skin changes, minor layout
changes, etc) the system will store multiple pieces of information about a component when generating an identification
string to retrieve it from a list of candidates. The system has a default strategy for choosing the order in which to
look at these pieces of information but in some cases this can be overridden by setting a LocatorStrategy
.
By default we use the following strategies in order to identify a component from a list of candidates:
name
: Does not apply in all cases but in cases where a specified name
attribute has
meaning we will use it - for example for sections
in a section stack
or images
. title
: If a title
is specified for the component this may be used as a legitimate identifier if it is unique within the component - for
example differently titled tabs within a tabset.index
: Locating by index is typically less
robust than by name or title as it is likely to be affected by layout changes on the page.If an explicit strategy is specified, that will be used to locate the component if possible. If no matching component is found using that strategy, we will continue to try the remaining strategies in order as described above. In other words setting a locatorStrategy to "title" will skip attempting to find a component by name, and instead attempt to find by title - or failing that by index.
In cases where the name is considered definitive, such as for Tabs
or FormItems
, no fallback check will occur if a name is provided in the locator but doesn't match a live object - the
locator will fail to match anything. Furthermore, in the case of Tabs
,
FormItems
, or collections other than children of a widget
, if a title is present in the locator and you
haven't specified specified "index" as the strategy, there may be no fallback check using the index if the locator title
fails to match.
To avoid the Framework trying to match by name or title where they are assumed definitive and we skip fallback to the remaining locator attributes, you'll need to remove the name or title from the locator in question (or set the locatorStrategy to "index" in the case of the title).
Note that we also support matching by type (see
LocatorTypeStrategy
). Matching by type is used if we were unable to match by name or
title or to disambiguate between multiple components with a matching title.
Enum Constant and Description |
---|
INDEX
Match by index
|
NAME
Match by name if possible.
|
TITLE
Match by title if possible.
|
Modifier and Type | Method and Description |
---|---|
java.lang.String |
getValue() |
static LocatorStrategy |
valueOf(java.lang.String name)
Returns the enum constant of this type with the specified name.
|
static LocatorStrategy[] |
values()
Returns an array containing the constants of this enum type, in
the order they are declared.
|
public static final LocatorStrategy NAME
If this enumerated value is used in a Component XML
file or server-side DataSource descriptor (.ds.xml file), use the value "name".
public static final LocatorStrategy TITLE
If this enumerated value is used in a Component XML
file or server-side DataSource descriptor (.ds.xml file), use the value "title".
public static final LocatorStrategy INDEX
If this enumerated value is used in a Component XML
file or server-side DataSource descriptor (.ds.xml file), use the value "index".
public static LocatorStrategy[] values()
for (LocatorStrategy c : LocatorStrategy.values()) System.out.println(c);
public static LocatorStrategy valueOf(java.lang.String name)
name
- the name of the enum constant to be returned.java.lang.IllegalArgumentException
- if this enum type has no constant with the specified namejava.lang.NullPointerException
- if the argument is null