-
-
Notifications
You must be signed in to change notification settings - Fork 354
Writing & Running Unit Tests
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 class you might need to test. Let's assume we have a Foo
class we need to test. We'll call this our container test class FooTests
. Inside FooTests
there can be many child classes. Each child class would typically represent a method or property of the parent test class. So our FooTests
class might have a child class called TheBarMethod
. Our TheBarMethod
class could contain as many individual test cases about that particular member of the Foo
class.
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...
}
}
- 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.
- Go to nunit.org's download page and download the latest MSI installer.
- Run the installer.
- Rebuild the Rock solution in Visual Studio.
- In the NUnit client open the
Rock.Tests.dll
under\Rock.Tests\bin\debug
. - 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.
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.