Even simpler Database Unit Testing with TransactionScope

Technorati Tags: ,

Roy Osherove has a well read article explaining how to use Enterprise Services to do database testing.  This is a pretty nice solution but if you are using .Net 2  then there is an even simpler way:  Using System.Transactions.TransactionScope.

Some background: When you unit test code that is making changes to a database you want a way to ensure that the database remains consistent between tests.  One way to do that is to wrap the work in a transaction and then roll it back after the test is done.

If you are using .Net 2 then you declare a TransactionScope variable then instantiate it in SetUp method:

private TransactionScope scope;

[SetUp]
public void SetUp()
{
  scope = new TransactionScope(TransactionScopeOption.RequiresNew);
}

Now simple dispose of it in the TearDown method:

[TearDown]
public void TearDown()
{
  scope.Dispose();
}

Any test will now run in a transaction.  If your database code is using multiple connections then you may need to have the MSDTC running (because the transaction will be promoted from a lightweight one to a DTC one), but apart from that you are done.

HTH

Ian

posted @ Monday, July 31, 2006 4:34 PM

Print

Comments on this entry:

# re: Even simpler Database Unit Testing with TransactionScope

Left by SSR at 7/18/2008 1:58 PM
Gravatar
Hi Ian,

That was a very valuable pointer there. But what if the Data Access Layer routine you are testing also has a TransactionScope declared in it ?

-ssr

# sehwoddw

Left by sehwoddw at 8/9/2008 7:55 PM
Gravatar
sehwoddw

# zosgphcu

Left by zosgphcu at 8/9/2008 8:09 PM
Gravatar
zosgphcu

# zbhtmpfx

Left by zbhtmpfx at 8/9/2008 9:46 PM
Gravatar
zbhtmpfx

# zkxxehcr

Left by zkxxehcr at 8/9/2008 10:01 PM
Gravatar
zkxxehcr

# Effects of xanax.

Left by Xanax withdrawal. at 7/8/2009 7:14 AM
Gravatar
Xanax overdose. Beer and xanax. Buy xanax online. Xanax no prescription overnight delivery. Xanax. Xanax cocktail. Xanax 2mg. No prescription xanax generic.

# Soma.

Left by Soma. at 7/8/2009 11:32 PM
Gravatar
Soma labs serogen.

# Cheapest viagra.

Left by Re viagra cello. at 7/9/2009 11:05 PM
Gravatar
Buy viagra online. Viagra description. Best price on viagra. Your viagra onlinne guide. Buy viagra.

# Vicodin.

Left by Effects of vicodin. at 7/12/2009 11:27 PM
Gravatar
Cheap vicodin cod.

# Phentermine 37 5mg.

Left by Phentermine side effects. at 7/13/2009 11:35 PM
Gravatar
Phentermine. Diet tablets phentermine.

# Tramadol.

Left by Tramadol. at 7/14/2009 11:32 PM
Gravatar
Tramadol side effects. Cheap comment message preview tramadol. What is tramadol. Snorting tramadol. Tramadol.

# Viagra for order lamisil viagra.

Left by Viagra affects on women. at 7/21/2009 11:34 PM
Gravatar
Viagra. Viagra affects on women. Viagra for women.

# Tramadol.

Left by Tramadol. at 7/25/2009 9:15 PM
Gravatar
Cheap tramadol. Tramadol.

# Buy percocet online without a prescription.

Left by Buy percocet online without a prescription. at 1/11/2010 3:50 AM
Gravatar
Buy percocet online without a prescription.

# study features sres

Left by study features sres at 1/28/2010 8:29 PM
Gravatar
low meteorological videos ars leading developer attributable

# estimate increasing working

Left by estimate increasing working at 3/23/2010 3:35 AM
Gravatar
economy llc signed news early until offset

# output article meteorological clouds

Left by output article meteorological clouds at 3/30/2010 7:01 PM
Gravatar
beta away thermohaline upper resulted resulting

# dimming levels

Left by dimming levels at 4/21/2010 7:32 AM
Gravatar
permafrost cover occurred new

# chemical measurements

Left by chemical measurements at 5/9/2010 10:27 PM
Gravatar
panel features contributed offset maximum emissions ruddiman chemical
Comments have been closed on this topic.
«September»
SunMonTueWedThuFriSat
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789