Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Applies to:  Visual Studio
Visual Studio  Visual Studio for Mac
Visual Studio for Mac
Note
This article applies to Visual Studio 2017. If you're looking for the latest Visual Studio documentation, see Visual Studio documentation. We recommend upgrading to the latest version of Visual Studio. Download it here
Coded UI tests can automate testing for web applications by recording your tests using Internet Explorer. You can then customize your test and play it back using either Internet Explorer or other browser types for these web applications. This article describes how to automate the tests using Selenium.
Note
Coded UI Test for automated UI-driven functional testing is deprecated. Visual Studio 2019 is the last version where Coded UI Test will be fully available. We recommend using Playwright for testing web apps and Appium with WinAppDriver for testing desktop and UWP apps. Consider Xamarin.UITest for testing iOS and Android apps using the NUnit test framework. To reduce the impact on users some minimum support will still be available in Visual Studio 2022 Preview 4 or later.
First, install the Selenium components for coded UI cross browser testing.
What's supported across all web browsers?
- Add custom code for controlling features such as properties, search, and playback waiters. 
- Pop-ups and dialog boxes 
- Search resilience (using smart match) and performance improvements 
Why should I use coded UI tests across multiple web browser types?
By testing your web application using a variety of web browser types, you better emulate the UI experience of your users who may run different browsers. For example, your application might include a control or code in Internet Explorer that is not compatible with other web browsers. By running your coded UI tests across other browsers, you can discover and correct any issue before it impacts your customers.
How do I record and play back coded UI tests on web applications using the supported web browsers?
Recording: You must use the Coded UI Test Builder to record your web application test using Internet Explorer. You can optionally add validation and custom code for the tested controls using a predefined set of properties as you would normally do for coded UI tests. For more information, see Use UI automation to test your code.
Note
You cannot record coded UI tests using Google Chrome or Mozilla Firefox browsers.
Play back with Internet Explorer: When no browser is explicitly specified, tests will run on Internet Explorer by default. You can explicitly state the browser to be used by setting the BrowserWindow.CurrentBrowser property in your test code. For Internet Explorer, this property should be set to IE or Internet Explorer.
Play back with non-Internet Explorer web browsers: To play back on non-Internet Explorer web browsers, change BrowserWindow.CurrentBrowser property in your test code to either Firefox or Chrome.
To play back tests on non-IE web browsers, you must install the Selenium components for Coded UI Cross Browser Testing.
Install Selenium components
- On the Tools menu, choose Extensions and Updates. 
- In the Extensions and Updates dialog box, search for - Selenium components for Cross Browser Testing.
- Highlight the extension and choose Download. - Tip - You can also download the Selenium components for Coded UI Cross Browser Testing from here. 
For more information about creating and using coded UI tests, see Create coded UI tests.
Enable debugging
To enable debugging your web application, you must complete the following configuration options:
- Enable Just My Code: - On the Tools menu, choose Options and then choose Debugging. 
- Select Enable Just My Code. 
 
- Disable CLR exceptions: - On the Debug menu, choose Exceptions. 
- For Common Language Runtime Exceptions, uncheck User-unhandled. 
 
If you don't see the option to change BrowserWindow.CurrentBrowser in the coded UI test, you might be using a version of Visual Studio that does not support coded UI tests using various web browsers. To use such coded UI tests, you must use Visual Studio Enterprise edition.
Here are some other things you should know:
- Apple Safari web browser is not supported. 
- The action of starting the web browser must be part of the coded UI test. - If you have a web browser already open and you want to run steps on it, the playback will fail unless you are using Internet Explorer. Therefore, it is a best practice to include the startup of your web browser as part of your coded UI tests. 
- Automating browser specific based UI actions such as maximize, minimize and restore is not supported. 
Tips
You can configure the output to include screenshots in the coded UI logs. To do so, you need to set some configuration settings in the QTAgent32.exe.config file. By default, this file is installed in the following location:
%ProgramFiles(x86)%\Microsoft Visual Studio\2017\Enterprise\Common7\IDE
Set the following values:
- EqtTraceLevelin the- system.diagnosticssection.
- <add name="EqtTraceLevel" value="4" />- By setting the value to 3 or higher, screenshots are taken for each action. When the value is set to either 1 or 2, screenshots are taken for error actions only. 
For more information, see Analyze coded UI tests using coded UI test logs.
Video resources
Record on IE and playback everywhere
Author cross browser tests with coded UI test builder
Author cross browser tests using plain hand coding without UI Map
Run cross browser tests sequentially on multiple browsers
Troubleshoot cross browser test failures