Automated Ui Testing Tools
Automated UI testing for web using automation tools ensures that the web app meets the design and development specifications and ensures a user-friendly website to end-users. Hence, this sort of automated web application UI testing is performed to find defects either in the functionality or in the design of the website quickly.
GUI testing tools serve the purpose of automating the testing process of software with graphical user interfaces.
Name | Supported platforms (testing system) | Supported platforms (tested system) | Developer | License | Automation | Latest version | Reference | Status |
---|---|---|---|---|---|---|---|---|
AscentialTest | Windows | Windows, Web | Zeenyx Software, Inc. | Proprietary | Yes | 9.4.1 | [1] | Active |
AutoIt | Windows | Windows | AutoIt | Proprietary | Yes | 3.3.14.5 | [2] | Active |
Appium | Windows, Linux, Mac (Python, C#, Ruby, Java, Javascript, PHP, Robot Framework) | iOS, Android (both native App & browser hosted app) | SauceLabs | Apache | Yes | (Binding Specific) | [3] | Active |
Blisk | Windows, Mac | Web | Blisk | Proprietary | Yes | 12.0.92.83 | [4] | Active |
Dojo Objective Harness | cross-platform | Web | Dojo Foundation | AFL | Yes | 6.0 | [5] | Active |
eggPlant Functional | Windows, Linux, OS X | Windows, Linux, OS X, iOS, Android, Blackberry, Win Embedded, Win CE | TestPlant Ltd | Proprietary | Yes | Unknown | [citation needed] | Active |
HP WinRunner | Windows | Windows | Hewlett-Packard | Proprietary | Unknown | Unknown | [citation needed] | Discontinued |
IcuTest | Unknown | WPF | NXS-7 Software Inc | Proprietary | Unknown | Unknown | [citation needed] | Discontinued |
iMacros | Web (cross-browser) | Unknown | iOpus | Proprietary | Yes | 12.5/10.0.5/10.0.2 | [citation needed] | |
Katalon Studio | Windows, Linux, OS X | Web (UI & API), Mobile apps | Katalon LLC | Proprietary | Yes | 6.3.0 | [6] | Active |
Linux Desktop Testing Project | Linux (With Windows and OSX ports) | GUI applications with accessibility APIs | (Collaborative project) | GNU LGPL | Yes | 3.5.0 | [7] | |
Maveryx | Windows, Linux, OS X (only Java technologies) | Java, Swing, SWT, AWT, RCP, VB, MFC, .NET, WPF, HTML5 (cross-browser), | Maveryx Srl | Proprietary | Yes | 2.4.1 | [8] | Active |
Oracle Application Testing Suite | Windows | Web, Oracle Technology Products | Oracle | Proprietary | Yes | 12.5 | [9][10] | Active |
QF-Test | Windows, Linux, OS X, Web (cross-browser) | Java/Swing/SWT/Eclipse, JavaFX, Web applications | Quality First Software GmbH | Proprietary | Yes | 4.7 | [11] | Active |
Ranorex Studio | Windows | Windows, Web, iOS, Android | Ranorex GmbH | Proprietary | Yes | 9.2.1 | [12] | Active |
Rational Functional Tester | Windows, Linux | Windows, Swing, .NET, HTML | IBM Rational | Proprietary | Yes | 8.6.0.7 | [13] | Active |
Robot Framework | Web (cross-browser) | Web | (Collaborative project) | Apache | Yes | 3.1.2 | [14] | Active |
Sahi | Web (cross-browser), Windows | Web, Java, Java Web Start, Applet, Flex | Tyto Software[15] | Apache and Proprietary | Yes | 5.1 (open source), 8.0.0 | [16][17] | Active |
Selenium | Web (cross-browser) | Web | (Collaborative project) | Apache | Yes | 3.141.59 | [18] | Active |
SilkTest | Windows | Windows, Web | Micro Focus previously Borland and Segue | Proprietary | Yes | 20.0 | [19] | Active |
SOAtest | Windows, Linux, (cross-browser) | Web (cross-browser) | Parasoft | Proprietary | Yes | 9.10.8 | [20] | Active |
Squish GUI Tester | Windows, Linux, macOS, Solaris, AIX, QNX, WinCE, Windows Embedded, embedded Linux, Android, iOS | Qt, QML, QtQuick, Java AWT, Swing, SWT, RCP, JavaFx, Win32, MFC, WinForms, WPF, HTML5 (cross-browser), macOS Cocoa, iOS, Android, Tk | froglogic GmbH | Proprietary | Yes | 6.5.1 | [21] | Active |
Test Studio | Windows | Windows, Test Studio, Android, iOS | Telerik by Progress | Proprietary | Yes | R2 2019 | [citation needed] | Active |
TestComplete | Windows | Windows, Android, iOS, Web | SmartBear Software | Proprietary | Yes | 14.10 | [citation needed] | Active |
Testing Anywhere | Unknown | Unknown | Automation Anywhere | Proprietary | Yes | 8.0 | [citation needed] | Discontinued |
TestPartner | Windows | Windows | Micro Focus | Proprietary | Yes | 6.3.2 | [citation needed] | Discontinued |
Tricentis Tosca | Windows | Windows, iOS, Android, Web, Cross-Browser, Java AWT, Java SWT, API, Win32, WinForms, WPF, Siebel, Delphi, PowerBuilder, up to around 40 different technologies | Tricentis | Proprietary | Yes | 12.2 Patch 04 | [22] | Active |
Twist | Unknown | Unknown | ThoughtWorks | Proprietary | Unknown | 14.1.0 | [citation needed] | Discontinued |
Unified Functional Testing (UFT) previously named HP QuickTest Professional (QTP) | Windows | Windows, Web, Mobile, Terminal Emulators, SAP, Siebel, Java, .NET, Flex, others..[23] | Hewlett-Packard Enterprise | Proprietary | Yes | 14.53 | [24] | Active |
Visual Studio Coded UI Test | Windows | Windows, Web | Microsoft | Proprietary | Yes | 12.0 | Unknown | Inactive[25] |
Watir | Web | Web (cross-browser) | (Collaborative project) | BSD | Yes | 6.16.5 | [citation needed] | |
Xnee | UNIX | X Window | GNU Project, Henrik Sandklef | GNU GPL | Unknown | 3.19 | [citation needed] |
References[edit]
- ^'Jolt Awards 2014: The Best Testing Tools'. Dr.Dobbs.com. June 3, 2014. Retrieved 2016-09-27.
- ^'AutoIt'. autolt. June 3, 2014. Retrieved 2016-09-27.
- ^'Mobile Phone automation'. appium. Retrieved 2018-12-11.
- ^'Blisk browser'. blisk.io. Retrieved 2019-07-09.
- ^'Dojo Toolkit'. DOJO. Retrieved 2016-09-27.
- ^Brian (2017-10-26). 'Best Automation Testing Tools for 2018 (Top 10 reviews)'. Medium. Retrieved 2018-05-22.
- ^'Linux Desktop Testing Project'. LDTP Website. Retrieved 2015-07-26.
- ^'Maveryx'. maveryx. Retrieved 2018-08-27.
- ^'Oracle - Oracle Application Testing Suite'. Retrieved 2016-11-08.
- ^'OATS - Oracle Application Testing Suite - Testingtools.co'.
- ^'QF-Test Overview'. QFS Website. Retrieved 2014-10-09.
- ^'Ranorex Release Notes'. Ranorex Website. Retrieved 2015-11-18.
- ^'Functional Tester'. IBM Website. Archived from the original on 2016-03-04. Retrieved 2016-03-08.
- ^'GUI Automation'. Sorted Inf. Retrieved 2014-02-22.
- ^'Sahi Open Source Vs. Sahi Pro'. Sahi Pro Website. Retrieved 2014-09-02.
- ^'Sahi — Web Automation and Test Tool'. Open-source Sahi on Sourceforge. Retrieved 2014-09-02.
- ^'Sahi — The tester's Web Automation Tool'. Sahi Pro Website. Retrieved 2014-09-02.
- ^'What is Selenium?'. Selenium HQ. Retrieved 2014-09-02.
- ^'Silk Test Overview'(PDF).
- ^'Parasoft Launches SOATest: Raising the Bar on API Integrity'. 2013-06-14. Retrieved 2018-10-16.
- ^'Squish GUI Tester'. froglogic Website. Retrieved 2017-12-07.
- ^'Tricentis Tosca'. Tricentis Tosca. Retrieved 2017-04-12.
- ^'More Add-ins'. uft-help.saas.hpe.com. Retrieved 2017-08-02.
- ^'What's New in UFT 14.00'. uft-help.saas.hpe.com. Retrieved 2017-08-02.
- ^'Changes to Coded UI Test in Visual Studio 2019'. Azure DevOps Blog. Retrieved 2019-04-15.
Note
This documentation is intended for .NET Framework developers who want to use the managed UI Automation classes defined in the System.Windows.Automation namespace. For the latest information about UI Automation, see Windows Automation API: UI Automation.
This overview describes how Microsoft UI Automation can be useful as a framework for programmatic access in automated testing scenarios.
UI Automation provides a unified object model that enables all user interface (UI) frameworks to expose complex and rich functionality in an accessible and easily automated manner.
Kotori diclonius free download. Due to its precise and elegant look, the first-rate typeface that is similar to that is an oddative majority of designers are utilizing it of their numerous initiatives.
UI Automation was developed as a successor to Microsoft Active Accessibility. Active Accessibility is an existing framework designed to provide a solution for making controls and applications accessible. Active Accessibility was not designed with test automation in mind even though it evolved into that role due to the very similar requirements of accessibility and automation. UI Automation, in addition to providing more refined solutions for accessibility, is also specifically designed to provide robust functionality for automated testing. For example, Active Accessibility relies on a single interface to both expose information about the UI and collect the information needed by AT products; UI Automation separates the two models.
Both a provider and client are required to implement UI Automation for it to be useful as an automated test tool. UI Automation providers are applications such as Microsoft Word, Excel, and other third-party applications or controls based on the Microsoft Windows operating system. UI Automation clients include automated test scripts and assistive technology applications.
Note
The intent of this overview is to showcase the new and improved automated testing capabilities of UI Automation. This overview is not intended to provide information on accessibility features and will not address accessibility other than where necessary. Dlp-ior4 drivers for mac.
UI Automation in a Provider
For a UI to be automated, a developer of an application or control must look at what actions an end-user can perform on the UI object using standard keyboard and mouse interaction.
Once these key actions have been identified, the corresponding UI Automation control patterns (that is, the control patterns that mirror the functionality and behavior of the UI element) should be implemented on the control. For example, user interaction with a combo box control (such as the run dialog) typically involves expanding and collapsing the combo box to hide or display a list of items, selecting an item from that list, or adding a new value via keyboard input.
Note
With other accessibility models, developers must gather information directly from individual buttons, menus, or other controls. Unfortunately, every control type comes in dozens of minor variations. In other words, even though ten variations of a pushbutton may all work the same way and perform the same function, they must all be treated as unique controls. There is no way to know that these controls are functionally equivalent. Control patterns were developed to represent these common control behaviors. For more information, see UI Automation Control Patterns Overview.
Implementing UI Automation
As mentioned earlier, without the unified model provided by UI Automation, test tools and developers are required to know framework-specific information in order to expose properties and behaviors of controls in that framework. Since there can be several different UI frameworks present at any single time within Windows operating systems, including Win32, Windows Forms, and Windows Presentation Foundation (WPF), it can be a daunting task to test multiple applications with controls that seem similar. For example, the following table outlines the framework-specific property names required to retrieve the name (or text) associated with a button control and shows the single equivalent UI Automation property.
UI Automation Control Type | UI Framework | Framework Specific Property | UI Automation Property |
---|---|---|---|
Button | Windows Presentation Foundation | Content | NameProperty |
Button | Win32 | Caption | NameProperty |
Image | HTML | alt | NameProperty |
UI Automation providers are responsible for mapping the framework-specific properties of their controls to the equivalent UI Automation properties.
Information on implementing UI Automation in a provider can be found at UI Automation Providers for Managed Code. Information on implementing control patterns is available at UI Automation Control Patterns and UI Automation Text Pattern.
UI Automation in a Client
The goal of many automated test tools and scenarios is the consistent and repeatable manipulation of the user interface. This can involve unit testing specific controls through to the recording and playback of test scripts that iterate through a series of generic actions on a group of controls.
A complication that arises from automated applications is the difficulty synchronizing a test with a dynamic target. For example, a list box control, such as one contained in the Windows Task Manager, that displays a list of currently running applications. Since the items in the list box are dynamically updated outside the control of the test application, attempting to repeat the selection of a specific item in the list box with any consistency is impossible. Similar issues can also arise when attempting to repeat simple focus changes in a UI that is outside the control of the test application.
Programmatic Access
Programmatic access provides the ability to imitate, through code, any interaction and experience exposed by traditional mouse and keyboard input. UI Automation enables programmatic access through five components:
The UI Automation tree facilitates navigation through the structure of the UI. The tree is built from the collection of hWnd's. For more information, see UI Automation Tree Overview
Automation elements are individual components in the UI. These can often be more granular than an hWnd. For more information, see UI Automation Control Types Overview.
Automation properties provide specific information about UI elements. For more information, see UI Automation Properties Overview.
Control patterns define a particular aspect of a control's functionality; they can consist of property, method, event, and structure information. For more information, see UI Automation Control Patterns Overview.
Automation events provide event notifications and information. For more information, see UI Automation Events Overview.
Key Properties for Test Automation
The ability to uniquely identify and subsequently locate any control within the UI provides the basis for automated test applications to operate on that UI. There are several Microsoft UI Automation properties used by clients and providers that assist in this.
AutomationID
Uniquely identifies an automation element from its siblings. AutomationIdProperty is not localized, unlike a property such as NameProperty that is typically localized if a product gets shipped in multiple languages. See Use the AutomationID Property.
Note
AutomationIdProperty does not guarantee a unique identity throughout the automation tree. For example, an application may contain a menu control with multiple top-level menu items that, in turn, have multiple child menu items. These secondary menu items may be identified by a generic scheme such as 'Item1, Item 2, Item3, etc.', allowing duplicate identifiers for children across top-level menu items.
ControlType
Identifies the type of control represented by an automation element. Significant information can be inferred from knowledge of the control type. See UI Automation Control Types Overview.
NameProperty
This is a text string that identifies or explains a control. NameProperty should be used with caution since it can be localized. See UI Automation Properties Overview.
Implementing UI Automation in a Test Application
Add the UI Automation References. | The UI Automation dll's necessary for UI Automation clients are listed here. - UIAutomationClient.dll provides access to the UI Automation client-side APIs. - UIAutomationClientSideProvider.dll provides the ability to automate Win32 controls. See UI Automation Support for Standard Controls. - UIAutomationTypes.dll provides access to the specific types defined in UI Automation. |
Add the System.Windows.Automation namespace. | This namespace contains everything UI Automation clients need to use the capabilities of UI Automation except text handling. |
Add the System.Windows.Automation.Text namespace. | This namespace contains everything a UI Automation clients need to use the capabilities of UI Automation text handling. |
Find controls of interest | Automated test scripts locate UI Automation elements that represent controls of interest within the automation tree. There are multiple ways to obtain UI Automation elements with code. - Query the UI using a Condition statement. This is typically where the language-neutral AutomationIdProperty is used. Note: An AutomationIdProperty can be obtained using a tool such as Inspect.exe that is able to itemize the UI Automation properties of a control. - Use the TreeWalker class to traverse the entire UI Automation tree or a subset thereof. - Track focus. - Use the hWnd of the control. - Use screen location, such as the location of the mouse cursor. See Obtaining UI Automation Elements |
Obtain Control Patterns | Control patterns expose common behaviors for functionally similar controls. After locating the controls that require testing, automated test scripts obtain the control patterns of interest from those UI Automation elements. For example, the InvokePattern control pattern for typical button functionality or the WindowPattern control pattern for window functionality. See UI Automation Control Patterns Overview. |
Automate the UI | Automated test scripts can now control any UI of interest from a UI framework using the information and functionality exposed by the UI Automation control patterns. |
Related Tools and Technologies
There are a number of related tools and technologies that support automated testing with UI Automation.
Inspect.exe is a graphical user interface (GUI) application that can be used to gather UI Automation information for both provider and client development and debugging. Inspect.exe is included in the Windows SDK.
MSAABridge exposes UI Automation information to Active Accessibility clients. The primary goal of bridging UI Automation to Active Accessibility is to allow existing Active Accessibility clients the ability to interact with any framework that has implemented UI Automation.
Security
For security information, see UI Automation Security Overview.