We have a project that is starting to get large, and we need to start applying Unit Tests as we start to refactor. What is the best way to apply unit tests to a project that already exists? I’m (somewhat) used to doing it from the ground up, where I write the tests in conjunction with the first lines of code onward. I’m not sure how to start when the functionality is already in place. Should I just start writing test for each method from the repository up? Or should I start from the Controllers down?
update:
to clarify on the size of the project.. I’m not really sure how to describe this other than to say there’s 8 Controllers and about 167 files that have a .cs extension, all done over about 7 developer months..
As you seem to be aware, retrofitting testing into an existing project is not easy. Your method of writing tests as you go is the better way. Your problem is one of both process and technology- tests must be required by everyone or no one will use them.
The recommendation I’ve heard and agree with is that you should not attempt to wrap tests around an existing codebase all at once. You’ll never finish. Start by working testing into your bugfix process- every fixed bug gets a test. This will start to work testing into your existing code over time. New code must always have tests, of course. Eventually, you’ll get the coverage up to a reasonable percentage, but it will take time.
One good book I’ve had recommended to me is Working Effectively With Legacy Code by Michael C. Feathers. The title doesn’t really demonstrate it, but working testing into an existing codebase is a major subject of the book.