Wednesday, May 18, 2005

Qualities of a Good Unit Test

Many developers, including me sorry to say, treat unit test code as a second class citizen. After all, NUnit test fixture classes aren't going into production, so why should you put a lot of time, effort, and thought into them? An unfortunate reality is that unit tests are rarely "write-only" code. Badly written unit tests or interdependent unit tests hamper refactoring or adding new code to the system. I've heard of teams that were afraid to add new code to a system because the changes would introduce test failures. One of the advantages of automated unit testing should be the ability to safely modify existing code. Bad unit tests turn this advantage on its head.

I'm giving an internal presentation today on mock objects and I prepared a slide on the "Qualities of a Good Unit Test." I actually couldn't find much in the way of resources on the web for this, so I made up the list below. I'd love to hear from the rest of you what your best practices are for unit tests.

Unit Tests Should Be Atomic

A unit test should only test a small piece of functionality. This falls inline with the idea of getting into a rhythm of "write a little test, write a little code." A litmus test is to ask yourself if any part of the unit test could stand alone in a separate unit test. Another feedback loop for your unit testing quality is the amount of time you spend with the debugger. If your unit tests are coarse, a test failure is more difficult to find. If the unit test exercises a small amount of code, the test failure cause can usually be spotted very quickly.

Order Independent and Isolated

There should never be an order dependency, intentional or not, between unit tests. Problems arise when one unit test leaves some kind of dirty data laying around. Testing against a database or some sort of static cache is a common culprit. The theme of the day was mocking (actually Episode III), so put evil stateful things behind nice, deterministic mocks or stubs.

Intention Revealing

A unit test can, and should, be a valuable form of documentation. At best, a unit test should explain the intended usage and function of a class. At worst, the unit test should still be easy to debug in the case of a regression failure. Excessive data setup can obfuscate a unit test beyond any hope of comprehension.

Easy to Setup

How easily can I set up an environment to run the tests? If the answer is "not very," I might never get the tests running. As much as possible, decouple unit tests from external dependencies like databases and web services by using mocks or stubs. When you do test against an external dependency, the dependency better be setup correctly by the automated build.

Runs Fast

You're never going to run the test just once. For the sake of constant feedback, successful continuous integration, and your sanity, make sure your tests run quickly. Thirty minute build and unit test cycles are nothing but friction. Just to keep in the mock rut, mock things that make network calls to speed up your testing. I like to segregate connected tests into a seperate assembly. This way you can quickly run the majority of your unit tests on demand without the lag from network calls.


There's surely some obvious things I'm missing, but I'm short on sleep (and a midnight movie awaits) at the moment so that's all I've got.

91 Comments:

Anonymous Jeffrey Palermo said...

I would go further and define a unit test. Then define an integration test. Then define an acceptance test. A unit test doesn't care about code outside of the component. External dependencies are mocked so that a unit test will only exercise a single componet. If a test crosses component boundaries (logical layers, network, database, etc), then it is not a unit test and is very hard to be run over and over in the build process. If the test calls across component boundaries, it is an integration test and requires environment setup to be run. An acceptance test exercises an entire feature from entry point to the deepest point in the call stack. I think those distinctions would help.

3:45 PM, May 18, 2005  
Anonymous Anonymous said...

Nice site!
[url=http://rxzgqjng.com/esvd/pdep.html]My homepage[/url] | [url=http://rdamksvz.com/qiht/gpat.html]Cool site[/url]

11:39 PM, September 20, 2006  
Anonymous Anonymous said...

Great work!
My homepage | Please visit

11:43 PM, September 20, 2006  
Anonymous Anonymous said...

Good design!
http://rxzgqjng.com/esvd/pdep.html | http://ptnncgbj.com/txfi/pdgn.html

11:43 PM, September 20, 2006  
Anonymous Frederic Torres said...

What about user interface ?
Can we talk about Dialog Unit Test ?

10:32 PM, February 20, 2007  
Anonymous <a href="http://www.xanga.com/buy_levitra">Buy Levitra</a> said...

Great article! Thanks.

6:31 PM, August 18, 2007  
Anonymous <a href="http://phentermine1.eamped.com">Phentermine</a> said...

Thanks for interesting article.

11:54 PM, August 18, 2007  
Anonymous <a href="http://search.cnn.com/search?query=site:m1.aol.com/phentermine4">Anonimous</a> said...

Nice! Nice site! Good resources here. I will bookmark!

6:54 PM, September 09, 2007  
Anonymous <a href="http://m2.aol.com/LorenLynn03/index8.html">Maxwells</a> said...

I see first time your site guys. I like you :)

4:40 AM, September 10, 2007  
Anonymous <a href="http://courses.cvcc.vccs.edu/ENG112_GROSS/_Chat_Room/000008fd.htm">Anonimous</a> said...

Excellent website. Good work. Very useful. I will bookmark!

4:14 PM, September 10, 2007  
Anonymous <a href="http://paydayadvisors.org">PaydayLoans</a> said...

UmbzAi You have a talant! Write more!

11:47 AM, October 30, 2007  
Anonymous <a href="http://tes.uab.es/MISS/portal_memberdata/portraits/twkgxziok">Auto insurance company</a> said...

Bu9Izp Hello all!

9:32 PM, October 30, 2007  
Anonymous <a href="http://hydrocodone.99k.org/index.php">Hydrocodone</a> said...

3OLaCE The best blog you have!

9:35 PM, November 01, 2007  
Anonymous <a href="http://users2.titanichost.com/buyviagra/144.html">apply for college loan</a> said...

bPpWkk Magnific!

12:23 PM, November 02, 2007  
Anonymous <a href="http://free.7host07.com/nmcfgy/226.html">almeria tour operators</a> said...

Good job!

1:16 PM, November 02, 2007  
Anonymous <a href="http://fioricet.clanteam.com/?pharma=87">buy fioricet online save $19.95</a> said...

Good job!

2:02 PM, November 02, 2007  
Anonymous <a href="http://celebrex.zxq.net/?pharma=2">100 celebrex mg</a> said...

Magnific!

2:58 PM, November 02, 2007  
Anonymous <a href="http://m1.aol.com/BrettHead14/287.html">insurance companies that specialize in churches</a> said...

Please write anything else!

4:02 PM, November 02, 2007  
Anonymous <a href="http://users2.titanichost.com/buyviagra/index14.html">get phentermine without a prescription</a> said...

Hello all!

5:34 AM, November 03, 2007  
Anonymous <a href="http://vicodin.newsit.es/buy-vicodin-online-no-prior-prescription.html">buy vicodin online</a> said...

Please write anything else!

10:11 AM, November 03, 2007  
Anonymous <a href="http://tramadol.newsit.es/i-had-withdrawal-tramadol.html">i had withdrawal tramadol</a> said...

Thanks to author.

11:14 AM, November 03, 2007  
Anonymous <a href="http://xenical.newsit.es/xenical-stories-of-side-effects.html">xenical stories of side effe</a> said...

Please write anything else!

12:17 PM, November 03, 2007  
Anonymous <a href="http://phentermine.whdot.com/index5.html">cheap phentermine buy pharmacy online now</a> said...

Wonderful blog.

1:05 PM, November 03, 2007  
Anonymous <a href="users2.titanichost.com/amalopra">JohnBraun</a> said...

J7nhka write more, thanks.

1:22 AM, November 04, 2007  
Anonymous <a href="http://users2.titanichost.com/popebatret/index12.html">couple sex pics</a> said...

actually, that's brilliant. Thank you. I'm going to pass that on to a couple of people.

9:36 PM, November 04, 2007  
Anonymous <a href="http://users2.titanichost.com/inoryum/index9.html">during pregnancy sex</a> said...

Nice Article.

10:11 PM, November 04, 2007  
Anonymous <a href="http://users2.titanichost.com/hviler/index4.html">animal toons sex</a> said...

Good job!

12:03 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/ansfur/index31.html">lebian sex stories</a> said...

Good job!

12:35 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/olds77/index23.html">latina anal</a> said...

Hello all!

1:12 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/shingro/index18.html">serena spice sex</a> said...

Wonderful blog.

1:42 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/scersi/index9.html">ebony gallery sex</a> said...

actually, that's brilliant. Thank you. I'm going to pass that on to a couple of people.

2:09 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/t1fielde/index16.html">oral sex galery</a> said...

Thanks to author.

2:43 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/adjutes/index14.html">beast stories sex</a> said...

Nice Article.

3:13 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/adjutes/index20.html">bart sex milhouse</a> said...

Magnific!

3:55 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/shiconta/index12.html">craigslist albuquerque sex</a> said...

Wonderful blog.

4:39 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/gnites3/index13.html">hot sex play</a> said...

Please write anything else!

5:12 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/marymeno/index16.html">prostatectomy and sex</a> said...

Thanks to author.

5:42 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/vadhoms/index16.html">male beastly sex</a> said...

What is a free gift ? Aren't all gifts free?

6:14 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/etooking/index34.html">ny wife sex</a> said...

Build a watch in 179 easy steps - by C. Forsberg.

6:53 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/swiseny/index30.html">doctor teens sex</a> said...

Hello all!

7:28 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/Lostsoldier3/index6.html">free no dwonload porn movies</a> said...

All generalizations are false, including this one.

7:54 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/pyzoid/index35.html">boy boy sex</a> said...

Oops. My brain just hit a bad sector.

8:23 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/pyzoid/index35.html">boy boy sex</a> said...

Give me ambiguity or give me something else.

8:59 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/selli83/index2.html">adult newsletter sex</a> said...

Clap on! , Clap off! clap@#&$NO CARRIER

9:31 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/numdaso/index32.html">islam premarital sex</a> said...

Change is inevitable, except from a vending machine.

10:04 AM, November 05, 2007  
Anonymous <a href="http://users2.TitanicHost.com/unite/hyperammonemia-steroids.html">hyperammonemia steroids</a> said...

Energizer Bunny Arrested! Charged with battery.

10:35 AM, November 05, 2007  
Anonymous <a href="http://cialis.whdot.com/index1.html">generic cialis pills stories</a> said...

Give me ambiguity or give me something else.

11:05 AM, November 05, 2007  
Anonymous <a href="http://frwebgate.access.gpo.gov/cgi-bin/leaving.cgi?to=freewebtown.com/phentermine1">phenterm</a> said...

What is a free gift ? Aren't all gifts free?

11:38 AM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/numdaso/index32.html">islam premarital sex</a> said...

What is a free gift ? Aren't all gifts free?

12:14 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/febisko/index32.html">belgium teen sex</a> said...

Save the whales, collect the whole set

1:01 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/topletrufus/index10.html">geocities celebrity sex</a> said...

Nice Article.

1:39 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/yetzeit/index8.html">asian bed sex</a> said...

When there's a will, I want to be in it.

2:10 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/brittanyrogers/index16.html">amatuer phone sex</a> said...

A flashlight is a case for holding dead batteries.

2:46 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/glicia80/index18.html">sex blowjobs xxx</a> said...

Energizer Bunny Arrested! Charged with battery.

3:17 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/reekello/index19.html">devil sex art</a> said...

Friends help you move. Real friends help you move bodies

3:41 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/tortene/index30.html">old ladies sex</a> said...

Clap on! , Clap off! clap@#&$NO CARRIER

4:08 PM, November 05, 2007  
Anonymous <a href="http://users2.TitanicHost.com/kiderg/cocaine-heroin-effects.html">cocaine heroin effects</a> said...

Give me ambiguity or give me something else.

4:40 PM, November 05, 2007  
Anonymous name said...

What is a free gift ? Aren't all gifts free?

5:08 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/cuhozhilov/index21.html">familt guy porn lois</a> said...

Hello all!

5:48 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/robertf/index6.html">rape porn websites</a> said...

Energizer Bunny Arrested! Charged with battery.

6:16 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/maxeevich/index34.html">adrianne curry porn</a> said...

When there's a will, I want to be in it.

6:57 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/dityroe/index25.html">lesbian sex videos</a> said...

The gene pool could use a little chlorine.

7:28 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/liperwo/index27.html">ass sex picture</a> said...

Magnific!

7:59 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/dasistorama/index21.html">free schoolgirl porn naked nude bab</a> said...

Please write anything else!

8:30 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/rego07/index6.html">teen porn fetish</a> said...

A lot of people mistake a short memory for a clear conscience.

9:06 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/artinko/index10.html">girl fucked by dog free preview beastal</a> said...

Friends help you move. Real friends help you move bodies.

9:52 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/lindafmosley/index32.html">anal sex women forum hood</a> said...

A flashlight is a case for holding dead batteries.

10:29 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/tereritoa1/index22.html">free turkish sex</a> said...

Good job!

11:04 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/eynol/index7.html">porn norway</a> said...

Oops. My brain just hit a bad sector.

11:46 PM, November 05, 2007  
Anonymous <a href="http://users2.titanichost.com/dentouj/index2.html">hector dog sex</a> said...

Change is inevitable, except from a vending machine.

12:15 AM, November 06, 2007  
Anonymous <a href="http://users2.TitanicHost.com/almaz/illegal-use-of-presciption-hydrocodone.html">illegal us</a> said...

Good job!

12:51 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/bybonte/index29.html">chabert lacey sex</a> said...

Good job!

1:39 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/unareq/index18.html">pic sex transgender</a> said...

Please write anything else!

2:16 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/mezers/index34.html">caleb sex tape</a> said...

Oops. My brain just hit a bad sector.

3:06 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/deswef/index4.html">cannes sex club</a> said...

Beam me aboard, Scotty..... Sure. Will a 2x10 do?

3:49 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/tedethe/index5.html">free messy sex</a> said...

All generalizations are false, including this one.

4:28 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/simpleplayer/index20.html">how to find reliable free porn</a> said...

Build a watch in 179 easy steps - by C. Forsberg.

5:12 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/sobermi/index18.html">install sex swing</a> said...

Save the whales, collect the whole set

6:09 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/clydej/index20.html">xxx porn passwords pics teens</a> said...

If ignorance is bliss, you must be orgasmic.

6:58 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/clydej/index20.html">xxx porn passwords pics teens</a> said...

If ignorance is bliss, you must be orgasmic.

6:59 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/xcalomi/index10.html">katies diary sex</a> said...

Friends help you move. Real friends help you move bodies.

7:48 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/ramisew/index6.html">predict baby sex</a> said...

Magnific!

8:23 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/hegory/index15.html">ass fucking porn videos</a> said...

Lottery: A tax on people who are bad at math.

9:02 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/sidspros/index10.html">teennap sex fantasy</a> said...

What is a free gift ? Aren't all gifts free?

9:41 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/whitedenster/index13.html">cell phone porn</a> said...

Good job!

10:12 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/MarcellaDurant/index7.html">1oo free sex</a> said...

What is a free gift ? Aren't all gifts free?

10:57 AM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/cationie1/index17.html">passionate couples sex</a> said...

Suicidal twin kills sister by mistake!

11:42 AM, November 06, 2007  
Anonymous <a href="http://phentermine.43i.net/565-061107.html">medlineplus drug information phentermine</a> said...

Wonderful blog.

12:20 PM, November 06, 2007  
Anonymous <a href="http://phentermine.43i.net/121-061107.html">buy herbal phentermine cheap prices</a> said...

Please write anything else!

1:08 PM, November 06, 2007  
Anonymous <a href="http://phentermine.43i.org/848-061107.html">phentermine overnight no prescription</a> said...

All generalizations are false, including this one.

2:00 PM, November 06, 2007  
Anonymous <a href="http://users2.titanichost.com/nimytre/index25.html">il sex offender</a> said...

Thanks to author.

2:37 PM, November 06, 2007  

Post a Comment

<< Home