![]() |
Development Lifecycle »
Testing and QA »
General
Beginner
License: The Eclipse Public License 1.0
RemoteInstall: Automated Testing of Windows Installers on VMWare InfrastructureBy dB.A framework for testing Windows installers with some help from virtualization. |
C#, XML, Windows, .NET, Win32, Win64, Architect, Dev, QA
|
|
Advanced Search Add to IE Search |
|
|
|
||||||||||||||||

RemoteInstall is a pragmatic approach to testing, and has been extremely successful at my day job. We went through several test framework iterations, and just couldn't get any automation going. We tried expensive systems and Open-Source stuff. We spent cash. We made automation a priority. It continued being a dead end.
In the meantime, we were authoring MSI installers like crazy. We had to deal with a large distributed system that was having a high deployment failure rate, a system made of many components. We had hundreds of upgrade paths, and it was clear that we needed to automate it. Seeing company automation efforts deadlocked, I decided that instead of trying yet another expensive test system, I'll have an intern write a simple tool that can leverage VMWare Infrastructure.
At its inception, RemoteInstall does this:
for each virtual machine {
for each snapshot {
restore the snapshot
install the software
report success or failure
}
}
Simple enough? You can get this behavior out of the box with a simple config file. Here's what the output looks like in CruiseControl. This tests an application for clean install and upgrades from various known snapshots.

The results were superb. We have virtually zero deployment failure in production for thousands of customers.
Then, eventually, we got pretty good at this, adding lots of useful features. If you have more than one VM, you can do this in parallel. RI integrates with build automation. It can pickup your latest installers from network shares etc.
Next, we thought: why not run some tests after each successful installation? So we added tasks and some simple integration. So you can execute JUnit or NUnit tests on the remote machine post-installation.

This made it into a full blown test framework. We now author tests in C# and Java and remote them via RI to run against multiple configurations.
The latest C# source code can be found in Subversion: https://remoteinstall.svn.codeplex.com/svn. Here're some interesting aspects of the code to get you started.
The RemoteInstall library is a modular approach that uses declarative syntax in the configuration files to drive execution.
VMWareTasks is used to control VMWare virtual machines and snapshots.
RemoteInstaller is a command-line tool that uses the RemoteInstall library to drive execution.
Download the latest version of RemoteInstall from CodePlex. Open the help file and follow the Getting Started guide.
| You must Sign In to use this message board. | |||||||||||||||
|
|||||||||||||||
|
|||||||||||||||
|
|||||||||||||||
|
|||||||||||||||
General
News
Question
Answer
Joke
Rant
Admin
Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+PgUp/PgDown to switch pages.
|
PermaLink |
Privacy |
Terms of Use
Last Updated: 24 Nov 2009 Editor: Smitha Vijayan |
Copyright 2009 by dB. Everything else Copyright © CodeProject, 1999-2010 Web10 | Advertise on the Code Project |