Skip to content

Writing & Running Unit Tests

JasonOffutt edited this page Nov 28, 2012 · 15 revisions

Phil Haack wrote a blog post in Jan 2012 introducing a really clever way of structuring your unit tests. We thought it was a great fit for our needs, so we're adopting it as well.

The gist of this structuring technique is to set up a single test class to contain all tests for any other class you might need to test. Let's assume we have a Foo class we need to test. We'll call our container test class FooTests. Inside FooTests there can be many child classes. Each child class would typically represent a method or property of our Foo class. So our FooTests class might have a child class called TheBarMethod. Our TheBarMethod class could contain as many individual test cases about the Bar method of the Foo class.

Example Unit Test with Class Structure

using Nunit.Framework;

[TestFixture]
public class FooTests
{
	public class TheBarMethod
	{
		[Test]
		public void ShouldReturnBar
		{
			// Arrange
			var foo = new Foo();

			// Act
			var result = foo.Bar();

			// Assert
			Assert.AreEqual(result, "bar");
		}
	}

	public class TheBazMethod
	{
		// TODO: Individual test cases for the `Baz` method will go in here...
	}
}

Tips for writing good automated unit tests with Nunit

  • Keep them short and sweet.
  • Break common/repetitive setup/teardown code out into helper methods.
  • Limit them to 1-2 assertions per test. Unit tests are meant to test a single specific behavior. If you have many assertions in your tests, it could probably be broken out into multiple tests.
  • Structuring a Unit Test
    • Arrange - Set up the expectations of the test, hydrate objects with mock data, etc.
    • Act - Execute the code being tested (usually a method call).
    • Assert - Compare the result of running the code to the requirements/expectations.

Running Unit Tests with Nunit Client

  1. Go to nunit.org's download page and download the latest MSI installer.
  2. Run the installer.
  3. Rebuild the Rock solution in Visual Studio.
  4. In the NUnit client open the Rock.Tests.dll under \Rock.Tests\bin\debug.
  5. Once it's loaded, click the green "Play" button to run your tests. Tests can be run one at a time, or in groups by selecting the relevant parent or child class, or run all at once by selecting the entire project.

Note

In addition to the Nunit client, there are several other solutions to running unit tests. Many of which can integrate directly into Visual Studio. We focused on the Nunit client here simply because it's the lowest common denominator, with possibly the lowest learning curve to get developers running their tests.

Clone this wiki locally