I was at a customer recently who have a small test database – around 120MB in size. I had encouraged them to use the DB Professional tools in VS 2010 to track their schema – that way they could deploy the database (as well as the latest schema) and some test data (through INSERT statements or even better, data generation plans). However, their developers didn’t have the time or skills (yet) to do this.
So we initially created the lab with a dependency on a database outside the Lab environment – an external database if you will. However, we were using Network Isolation and had numerous instances of the Lab environments – so contention on the external database was a risk.
The Lab with the External DB Dependency
I suggested that we install SQLExpress within the Lab environment (since we didn’t have a database VM in the environment, we just installed it on the Client VM where the tests are running). We could have restored a backup of the external database into the Lab as part of the “Clean” snapshot (allowing the Lab to start with a known database), but this would mean any changes to the database schema or lookup data would require someone re-create the snapshot.
So we came up with another solution: we created a shared folder on the network and placed a backup of the database into this folder. Then in the deployment section of the Lab Workflow, we added a script to copy the backup to a folder on the Lab machine (in this case, c:\data). The last step is to use sqlcmd to restore the database as follows (paths and dbnames depend on your environment, of course):cmd /c sqlcmd -S .\SqlExpress -Q "RESTORE DATABASE Demo FROM Disk='c:\data\Lab DB.bak' WITH MOVE 'DataLogicalName' TO 'c:\data\Lab DB.mdf', MOVE 'LogLogicalName' TO 'c:\data\Lab DB.ldf'"
where DataLogicalName and LogLogicalName are the logical names of the data and log files within the backup.
This approach allows you to “deploy” schema changes by refreshing the backup on the shared location. If you add a new table or something that the code requires, simply backup the new database to the shared location and you’re done.
The Lab at the “Clean” Snapshot
The Lab after deployment