By definition, a unit test is an automated piece of code that invokes the method or class being tested and then checks some assumptions about the logical behavior of that method or class. Here logical code means code having an IF statement, a loop, switch, some sort of calculation, or decision making code. (referenced from the book "The Art of Unit Testing").
The book goes on to point out properties of a good unit test are:
- It should be automated and repeatable
- It should be easy to implement
- Once it’s written, it should remain for future use
- Anyone should be able to run it
- It should run at the push of a button
- It should run quickly
Why unit test you may ask. Some answers include:
- Helps find problems early in the development cycle
- Facilitates changes with regression testing being automated
- Simplifies integration testing
- Provides a living documentation
- Allows for test-driven development (TDD)
- Can only show the presence of errors not the absence (like all testing)
- By definition cannot catch integration or performance errors
- Time and effort needed, e.g. for more features… others?
Recommended Unit Testing framework in the C++ world: GoogleTest + GoogleMock.