How to Automate Silverlight Tests in TFS Builds
The first step is to setup our Visual Studio solution correctly. It needs to contain three projects:
The Silverlight application.
A web project that will host the Silverlight application within a web page.
A test project that will contain our automated tests.
To create this combination in a fresh and new Visual Studio solution:
From File -> New Project select "Silverlight Application". This will automatically create a Silverlight application project and a web project that references the new Silverlight application project. Your new Visual Studio solution now shows two projects. Next we'll add a test project to the solution to hold our Test Studio automated tests that will run against the Silverlight application we're developing.
Right click on the root node in Solution Explorer and select "Add -> New Project...".
Expand the Telerik node and select either the "Visual Basic Test Studio Project" or the "Visual C# Test Studio Project". This will add a new test project to your solution as well as add a sample Test Studio test to it. You can keep or delete the sample test because it is not needed for our Silverlight automated testing.
At this point you can begin working on your Silverlight application. Once you have something working let's get our first test running against our new Silverlight application. We'll start by recording our test.
We will use the ASP.NET development server that comes with Visual Studio to act as our web server hosting our Silverlight application. In order to make recording and playback reliable we need to configure the development server to use a fixed port instead of a variable port. If we were to let it use a variable port and that port number changes between recording and playback, our tests will suddenly start failing on the initial NavigateTo steps.
Right click on the xxxxx.Web node in Solution Explorer and select Properties. This will open the properties for the web project.
Click Web from the list of tabs on the left.
Click Specific Port.
Enter a valid port number. Any number between 1024 and 65535 should work just fine.
The default settings for everything else should be just fine. Save your changes and close the properties window.
To setup for recording we first have to make the Silverlight application run in a browser window without initiating the Visual Studio debugger. In Visual Studio, within the "xxxxx.Web" project, right click on either the .aspx file or the .html file and select "View in browser". This will start the ASP.NET development server to serve up the web pages and Silverlight application locally and then load your Silverlight application in a new browser window. Now that our Silverlight application is running in a browser window, we're ready to launch the Test Studio recorder and record our test.
Now we're going to start recording.
Add a new Web test to the test project or open an existing one.
Click the Record button in Visual Studio.
Copy the URL that appears in the browser window that was previously opened and is showing your Silverlight application.
Paste this URL into the IE window that just opened when you clicked Record.
Click the Go To arrow button in IE.
This should record a NavigateTo step and cause your Silverlight application to appear in our IE recording window.
Finish recording and perfecting your test until you're happy with it.
Unfortunately the default properties recorded for the NavigateTo step do not quite work for executing tests using the ASP.NET development server. The change is simple however. We just need to trim the beginning of the URL. Remove the "http://localhost:5008" portion (yours may be different if you use a different port number) of the NavigateUrl property and replace it with a ~ like this:
Once you are satisfied that your test meets your needs we need to run it one more time from Visual Studio Test View to insure it will run properly as part of a TFS automated build. In preparation of this we need to create at least a couple of .testsettings files. One will be used for running tests in the TFS build and the other will be used for running tests locally from Test View. Optionally you can add a third .testsettings file that can run tests that won't use the ASP.NET Development Server (such as Test Studio tests that need to hit a live website).
Let's configure our LocalAspNetDevServer.testsettings file first.
Double click on the to open it.
Click Web Test on the left.
Click the General tab at the top.
-
If you're using VS 2010, select AspNetDevelopmentServer40 from the "Local Web Server Type" drop down. Otherwise select AspNetDevelopmentServer from the dropdown.
Set the Local Web Server Port to the same value you used during recording i.e. the same value you entered for the "Specific port" of your xxxxx.web project.
-
Next we need to set the path to our web files for the ASP.NET development server. Click on the File Paths tab and set "Web App Physical Path" to the full path to the xxxxx.web project folder located on your local hard drive e.g. "C:\Users\gibson\Documents\Visual Studio 2010\Projects\SilverlightAppTesting\SilverlightAppTesting.Web".
The default setting for rest of the properties should be just fine.
Make sure that LocalAspNetDevServer.testsettings is the active .testsettings file. In Visual Studio click Test then go to Select Active Test Settings and click on LocalAspNetDevServer.testsettings.
Now we're ready to test running our application from Test View.
Open Test View in Visual Studio.
Right click on your test from the list and select Run Selection.
A whole series of events should happen and if everything is setup correctly, your test will run and pass.
-
The ASP.NET Development Server should start up.
-
An IE window should open and load your Silverlight application.
-
Your test should run and pass.
We have one more step to perform before checking in our files into TFS source control. Because the Web App Physical Path will be different on your build server than your local machine we need to create another .testsettings file to be used by the automated build. You can open the current LocalAspNetDevServer.testsettings file, save it to a new file, e.g. AspNetDevServer.testsettings, then modify the Web App Physical Path to match where your TFS build machine will place the files during the build process. The correct path is going to be a combination of the TFS server configuration, build server configuration and the location in source control of the project. On my build server the path works out to be "C:\Builds\4\TestLabProject\SilverlightAppTesting\Binaries_PublishedWebsites\SilverlightAppTesting.Web".
The last project level setting we need to change just prior to check-in is to set "Copy to Output Directory" for all of our .aii tests to either "Copy Always" or "Copy if newer". Either setting will work.
Now save everything to disk and check-in the entire solution into TFS. We're ready to start working on the build server side of things.
In order for Silverlight tests to successfully run we need to configure our TFS Build Service to run as an "Interactive Process".
Click Start -> All Programs -> Microsoft Team Foundation Server 2010 -> Team Foundation Administration Console.
Click Build Configuration on the left.
Click Properties for the Build Service.
If your build service is already running, click "stop to make changes".
Select "Interactive Process"
-
Enter credentials for a real domain account that has the necessary permissions to access TFS and perform builds.
Click Start to restart the build service. A new window should open for your interactive build process. You can minimize this window, but do NOT close it. If your close it you effectively shut down your build service which will prevent builds from running.
Now we're ready to put together the build process for our new Silverlight project. Start by creating a new build definition within Visual Studio. I won't go through all of the settings that are required to complete a build definition as the list is extensive. We only need to focus on the "Automated Tests" section found on the Process tab of the build definition.
The above sample is a complex sample that demonstrates how to run some tests using the ASP.NET development server and some tests without the ASP.NET development server. I chose to use a naming convention for all of my tests. Any test that where the name contains "DevServer" will be executed using the ASP.NET development server while any test where the name contains "Live" will also be executed but without the ASP.NET development server. Notice how different .testsettings files are used for the different test groups. I have setup AspNetDevServer.testsettings to start the ASP.NET Development Server and point it to the path of where my Silverlight application was build on my build server. The IESettings.testsettings is configured to not use the ASP.NET Development Server. The "**" part of the Test Assembly Filespec means "recursively search all folders within the solution".
For a more simple configuration, you can set the Test Assembly Filespec to "*\.aii" and not create a second test assembly section. This cause the build to run all of your Test Studio tests using the same .testsettings file.
Go ahead and save your build configuration and queue a new build. If everything is configured right your build will run, the automated tests will run and pass. That's it!