|The information below concerns legacy mobile tests that work with mobile devices connected to the local computer. In new cloud-compatible mobile tests, the test engine recognizes controls by their accessibility info.|
TestComplete can recognize iOS TextField controls in iOS applications. It provides special properties and methods that let you retrieve the controls data and simulate user actions on the controls (see below).
In order for TestComplete to be able to work with iOS TextField controls, the following requirements must be met:
You must have an active license for the TestComplete Mobile module.
Your tested iOS application, the devices and the computer where TestComplete runs must be configured in a special way as it is described in the topics of the Preparing Applications, Devices, and Test Computers for iOS Testing (Legacy) section.
The control’s class name must be specified in the iOS Controls | Text field group of your project’s Object Mapping options. By default, this group contains the following item:
To command TestComplete to recognize instances of the specified class’s descendants as iOS TextField controls, select the Derived Classes check box next to the control’s class name.
You can also command the test engine to recognize custom controls as iOS TextField controls. See below for information about this.
If you experience issues when working with the controls, select File > Install Extensions from the TestComplete main menu and check whether the plugin is active. (You can find the plugin in the Mobile group.) If the plugin is not available, run the TestComplete installation in the Repair mode.
Recognizing Custom Controls
To command TestComplete to recognize your custom controls as iOS TextField controls:
Open your project’s Object Mapping options.
Add the control’s class name to the iOS Controls | Text field group.
If you do not know the control’s name, you can ask the control’s developers, or you can view the control’s
ObjectClassNameproperty in the Object Browser panel. As an alternative, you can click Add From Screen and select your custom control on screen. TestComplete will retrieve the control’s class name and add it to the selected mapping group automatically. For detailed information, see Object Mapping.
Once the control is mapped, it gets all the properties, methods and actions specific to the iOS TextField control.
If the specified custom control does not fit the control’s type, then it may not properly respond to commands that TestComplete sends, so recording or playing back user actions over the tested control will cause errors.
When testing iOS TextField controls, you can use properties and methods specific to these controls, as well as properties and methods that TestComplete applies to tested objects, onscreen objects and window objects. For the full list of available properties and methods, see the following topics:
During the test recording, if you do not press Return (Enter) at the end of the text input in the control, TestComplete will record the input as setting the
For IOS 13: The Keys action might not work if the
iOS TextFieldcontrol is set to disable text copying (
secureTextEntry = true) and if an input string contains symbols from a language that differs from the keyboard language. In such cases, use the
SetTextaction instead of