When designing for testability there are two separate domains of software to design, the code to be tested and the code that tests. In his blogpost Alexander elaborates on the necessity to make the interior of code (i.e. parts that normally would have private or internal visibility) public, in order for it to be testable. While I agree on the central issue that testability is more important than encapsulation, it is still a case of TDD design goals interfering with OO design goals.
Now, what if we - instead of asking what to do about code to make it testable - turn around and consider how to design testing code with an ability to test interiors? Of course, the obvious solution (illustrated below) is to place test classes responsible for testing code with internal visibility inside the project containing the code to be tested, and likewise, test methods responsible for testing code with private visibility inside the containing class.
A major flaw in the above method to test the interior is that your executables will contain test code. While it is possible to avoid this using preprocessor directives, testing should really be handled by the compiler, IDE and testing framework analogous to the way compiler and IDE handles debugging.
No comments:
Post a Comment