Applies to TestComplete 12.60, last modified on September 17, 2018

What is the Name Mapping repository?

The Name Mapping repository stores all the objects of your tested applications that your automated tests use. For each object, the Name Mapping repository has an alias (a descriptive name used in tests), the object’s position in the application’s object hierarchy, the criteria by which TestComplete identifies the object in the application uniquely, and (optionally) an image:

Desktop

Mapped objects of a desktop application

Click the image to enlarge it.

Web

Mapped objects of a web application

Click the image to enlarge it.

Mobile

Mapped objects of a mobile application

Click the image to enlarge it.

Each project can have only one Name Mapping repository. To add Name Mapping data from another test project, you can merge the external Name Mapping repository into the local one.

Why use name mapping

The Name Mapping repository stores object identification information separately from tests making test maintenance easier. If your application changes, you will not have to change your tests. You will only have to update the Name Mapping repository.

You can also specify user-friendly names (aliases) for your tested objects. This way your tests will be shorter and easier to read and maintain.

How name mapping works

When recording tests, TestComplete adds objects to the Name Mapping repository automatically. You can also add objects manually at design time. For each object, TestComplete specifies the properties and values that uniquely describe this object in the application. When mapping objects, TestComplete compares them with the objects stored in the Name Mapping repository and maps only those objects that are not mapped.

When running tests, TestComplete uses the Name Mapping repository to find objects in your tested application. If TestComplete cannot find an object (for example, if the object properties have changed, or there are several objects with these property values), the test fails. In this case, you need to update the mapping criteria to use unique, unchangeable properties for object identification.

Adding objects to the Name Mapping repository

Object identification criteria

To find an object in an application, the Name Mapping repository can use:

To customize the default identification properties that TestComplete uses to map objects, you can create templates.

Aliases and mapped objects

The Name Mapping repository includes two trees:

Mapped Objects and Aliases trees

Click the image to enlarge it.

  • Mapped Objects (hidden by default) - Shows all the objects (windows, dialogs, pages, and controls) found in your tested application. The Mapped Objects tree matches the application’s object hierarchy (you can also view it in the Object Browser). TestComplete needs to know the exact position of the object in the hierarchy to find it during the test run.

    The mapped name shows the object position in the Mapped Objects tree, and reflects its position in the application hierarchy:

    Mapped name in the Name Mapping repository

    You can use the mapped name to address objects from tests. However, it is more convenient to use aliases for this purpose (see below).

    If your application’s object hierarchy changes, update the Mapped Objects tree to reflect the changes. See Update Name Mapping. If your tested application’s hierarchy changes dynamically, you can move an object to the first stable parent skipping all the dynamic levels and then configure TestComplete to search for the object on all the levels down the hierarchy. See Extended Search.

  • Aliases - Objects in the Name Mapping repository can have an alias – a user-friendly name, for example, ButtonOK or linkProducts. Aliases are used to refer to objects in tests.

    Alias in the Name Mapping repository

    In script tests, you use full aliases, that is, the full hierarchy path of the object in the Aliases tree. In keyword tests, you do not actually see the full hierarchy path, because TestComplete shows a short notation for easy viewing.

    Accessing objects by their aliases from keyword tests

    Accessing objects by their aliases from keyword tests

    Accessing objects by their aliases from script tests

    Accessing objects by their aliases from keyword tests

    You can exclude intermediary objects from the Aliases tree to shorten object names. Suppose, you have an object with the fully-qualified alias Aliases.Orders.OrderForm.Group.groupBox1.Total. To exclude the intermediary Group and groupBox1 levels, you can move the Total item up the Aliases tree to the OrderForm item. In this case, to address the object from tests, you will use the object’s new alias – Aliases.Orders.OrderForm.Total.

    Excluding intermediary levels from the Aliases tree

    If you change the object hierarchy in the Aliases tree, the name used to address the corresponding objects in your tests must be updated as well. In keyword tests, TestComplete will suggest to update the name automatically. In scripts, you will have to update the name manually.

    By default, TestComplete generates an alias when you add an object to the Name Mapping repository (it is based on the object type) and text and/or a native name. You can change the default alias, for example, to a more descriptive name. See Rename Objects in the Name Mapping Repository.

You change the hierarchy in the Aliases and Mapped Objects trees by using drag-and-drop. To move an item to a different hierarchy level, drag it to the target location in the tree. TestComplete will move it along with all its child items.

How TestComplete searches for mapped objects

When a test addresses an object by its alias, TestComplete does the following:

  1. In the Mapped Objects tree, it finds an item that corresponds to the alias.

  2. Searches for the corresponding object in your system, starting from the top-level item in the Mapped Objects tree and moving down the hierarchy to the target item. It searches for each item on the appropriate level of the application hierarchy. If Extended Find is enabled, it will also search for the item on the following hierarchy levels as well.

    To find each item, it uses its specified identification criteria.

How TestComplete searches for mapped objects

Click the image to enlarge it.

Notes
  • The object hierarchy in the Aliases tree and in the Mapped Objects tree must not contradict the parent-child relationships of the corresponding objects in the application.

  • Unlike aliases, mapped objects cannot be moved to the topmost hierarchy level. The topmost mapped objects can be Sys or Mobile.

  • You can refer to objects in tests by their names both in the Aliases tree and in the Mapped Object tree. In the latter case, precede the object name with NameMapping.Sys or NameMapping.Mobile rather than with the Aliases prefix.

  • If an object does not have an alias, TestComplete will address it by its name in the Mapped Objects tree. If an object has several aliases, TestComplete will use the first alias with the shortest mapped name it finds.

Keeping the Name Mapping repository up to date

If the object hierarchy or property values used as identification criteria have changed in the application and they differ from the ones the Name Mapping repository stores, TestComplete will not be able to find tested objects. To learn how to check whether the hierarchy and identification criteria in your Name Mapping repository are correct and how to update them, if needed, see Update Name Mapping.

Working with objects that are not in the Name Mapping repository

Automated tests can also work with objects that are not in the Name Mapping repository. To refer to such objects, you can use the syntax used in the Object Browser. See About Object Browser Naming Notation.

If you do not want to store your tested objects in the Name Mapping repository, you can disallow TestComplete to add objects to it automatically when you are recording or editing tests. To do this, disable the Engines > Name Mapping > Map object names automatically option.

See Also

Name Mapping
About Name Mapping Editor

Highlight search results