UI Automation in WPF DateTimePicker (DateTimeEdit)
2 Jun 20211 minute to read
Microsoft UI Automation is the new accessibility Framework for Microsoft Windows, available on all operating systems that support Windows Presentation Foundation (WPF). UI Automation provides accessibility to most UI elements and it provides the information about UI element to the end user. You can interact with the UI by using automated test scripts. To know more about UI Automation, refer the MSDN page here.
DateTimeEdit supports the following types of UI Automation,
- Quick Test Professional
- Coded UI
Quick Test Professional (QTP)
The QTP tool can recognize the
DateTimeEdit control. Hence with the
DateTimeEdit control, it is possible to record interactions such as opening the calendar popup, closing the calendar popup, choosing the date from the calendar , setting the DateTime value and and so on, for testing using QTP.
Mapping the control to the custom server
QTP Tool interacts with the control through CustomServerBase extension through the RunInterface. The custom server must be mapped to the control type for the tool to identify the control. A conventional configuration file (*.cfg) will resemble the one shown in the following code snippet. When the configuration file and the assembly containing the server type are loaded, QTP will recognize the control and record it.
<?xml version="1.0" encoding="UTF-8"?> <Controls> <Control Type="Syncfusion.Windows.Shared.DateTimeEdit" MappedTo="SfDateTimeEdit"> <CustomServer> <Component> <DllName>Syncfusion.QtpDateTimeEdit.Wpf.dll</DllName> <TypeName>Syncfusion.Windows.Controls.QTP.DateTimeEditServer</TypeName> </Component> </CustomServer> </Control> </Controls>
This XML configuration file should contain the fully qualified type name of the control, fully qualified name of the custom server and the name of the assembly containing the custom server. MappedTo attribute, points to the name of the ClassInfo (an XML file containing the API information about the RunInterface).
You can refer the Coded UI document from here