TestComplete allows you to perform functional testing of web applications to verify that they work correctly. You can record and play web page navigation, logging in and out, filling out and submitting forms, searching product catalogs, placing orders and other operations. You can also insert checkpoints to verify data and attributes of web page elements, link validity and the web page structure and accessibility.
This topic provides an overview of automated web testing with TestComplete.
TestComplete lets you test web applications in the following web browsers:
Microsoft Edge (both 32- and 64-bit versions)
Microsoft Internet Explorer 10 - 11 (both 32- and 64-bit versions)
|Note:||The Modern UI (Metro) versions of Internet Explorer 10 and 11 are currently not supported.|
Google Chrome 77 (both 32- and 64-bit versions)
If you have a TestComplete version earlier than 12.42, your version of the SmartBear Test Extension will be incompatible with newer versions of the Chrome web browser. To test web applications in Chrome 77, you will have to upgrade your TestComplete to some later version. We recommend using version 14.20.
If you use a later version of Google Chrome, check whether a patch is available for it.
Chrome running in Modern UI (Metro) mode is currently not supported.
Mozilla Firefox 60 ESR, 67 - 69 (both 32- and 64-bit versions)
If you use a later version of Firefox, check whether a patch is available for it.
Applications with embedded Microsoft WebBrowser controls
Applications with the Edge-based WebBrowser control
Applications with Chromium Embedded Framework controls (both 32- and 64-bit editions)
|Each supported browser has certain specifics that should be taken in account during automated web testing. Read Considerations for Web Testing for details.|
TestComplete web tests are cross-browser, which means you can record tests in one browser and run them in another browsers, instead of having to create individual tests for different browsers.
TestComplete works with web pages through their GUI that does not depend on the technology used on the server. It can test web applications created with ASP, ASP.NET, PHP, CGI and other technologies.
TestComplete supports various web controls: standard HTML elements, jQuery UI, YUI, GWT, Developer Express, Telerik controls and others. It records and simulates interactions with these controls using high-level object-specific operations and provides checkpoints for verifying data and properties of these controls.
You can create automated tests for Rich Internet Applications, such as Adobe Flash, Flex and Microsoft Silverlight.
You can create tests by recording operations in a web browser, or you can create tests manually. Usually, it is easier to record a test first and then modify and enhance it.
When you are recording a test, you interact with the tested web application as an end user would: navigate to pages, fill out forms and so on. TestComplete captures all the actions you performed in the web browser and adds them to the test.
A web test typically starts with the operation that opens the tested web site in the browser.
The other test commands define various interactions with web pages and elements. For example, the sample test below fills out and submits a login form:
By default, the recorded tests use object names specified in Name Mapping (the “object repository”). For example, the
Aliases.browser object corresponds to the web browser launched by the test. It is an abstract object that matches the currently used browser rather than a specific browser. So, if you select another browser for a test run, the
Aliases.browser object will point to the new browser.
The recorded tests can be modified and enhanced in a number of ways to create more flexible and efficient tests. For example, you can:
Add new operations, reorder them and modify their parameters.
Delete or disable unneeded operations (for example, unneeded recorded commands).
Create data-driven tests that run multiple test iterations using different sets of data.
Insert checkpoints for verifying:
To get started with creating automated web tests, walk through the Testing Web Applications - Tutorial. It is recommended for novice users and for users who do not have experience in automating web tests.
To learn more about creating and enhancing web tests, refer to the following topics.
|To learn more about…||See these topics…|
|Recording web tests||Creating and Recording Web Tests|
|Creating and editing tests manually||Keyword Tests and About Script Tests|
|Launching web browsers||Launching Browsers|
|Finding objects on web pages||Common Tasks for Web Testing|
|Verifying web page elements||Using Checkpoints With Web Controls|
|Verifying web page contents||About Web Accessibility Checkpoints
About Web Comparison Checkpoints
|Common tasks that you perform to create tests in TestComplete||Common Tasks for Web Testing|
|Examples of typical web testing solutions||Web Testing - Examples|
|Running web tests||Running Tests|
|Running multiple test iterations using data from an external file||Data-Driven Testing|
TestComplete enables you to perform cross-browser compatibility testing across multiple web browsers. You can record web tests in any supported browser and then run tests in other browsers with no or minimum changes in the test logic or Name Mapping (the “object repository”). There is no need to create individual tests for different browsers, which simplifies test development and maintenance greatly. For more information, see Cross-Browser Testing in TestComplete.
The following image shows web test objects that TestComplete uses to work with web browsers and web pages:
A web browser is represented by the
Browser test object that is a child object of the root
Sys object that, in its turn, represents the operating system.
Browser test object has the following child objects:
One or more
Page objects corresponding to web pages that are open in browser tabs. They provide further access to web page elements.
One or more
BrowserWindow objects that correspond to browser windows. These objects provide operations for automating the browser window: maximizing, minimizing, resizing, positioning on screen, closing and so on.
Browser objects corresponding to Firefox also have a child
UIPage object that exposes Firefox’s XUL-based UI elements - the address bar, menu items and so on.
To view the objects that TestComplete identifies on a web page, expand the
Page object in the Object Browser:
The child object hierarchy of the
Page object depends on the web object model selected in the test project. The image above illustrates the hierarchy formed by the Tree model. This model is used for cross-browser testing and by default is applied to new TestComplete projects.
In other web object models, the web page object tree has another structure and uses another object naming. For complete information about object tree models and naming concepts, see Understanding Web Object Identification and Object Models.
To see the web object properties and methods available for use in tests, you can use the Object Browser or Object Spy. The available methods and properties include those provided by TestComplete, as well as those provided by the web browser (for example, DOM methods and properties).
Important: some web element methods and properties provided by web browsers are not displayed in the Object Browser and Object Spy by default. For example, this happens to objects that return style information and that are accessed through the
runtimeStyle property. If you try to view methods or properties of such objects, TestComplete will display an empty list in the Object Browser or Object Spy.
To view a complete list of object methods and properties, enable the Show hidden members option in Tools | Options | Engines.
Depending on the web browser you are using and depending on the web page type, the properties of some web elements can be displayed on the Fields tab of the Object Browser or Object Spy. This is how the browser returns information about properties. So, if you do not find a property on the Properties tab, search for it in Fields.
You can view object properties and methods both at design time and at run time if the test is paused.
Using native properties and methods of web elements, you can get their data, state and style and automate specific operations that are not available through TestComplete built-in operations.
For more information on using web element members provided by web browsers, see Accessing Native Web Attributes and Methods.
TestComplete includes a number of sample web applications and test projects for them. You can examine these samples to better understand how to implement some common automated testing scenarios. See Web Testing Samples.