π 55686844_zps86380239
This post is part of the βLegacy Code to Testable Codeβ series. In the series weβll talk about making refactoring steps before writing tests for legacy code, and how they make our life easier.
In the last post, Iβve talked about Extract Class, and that sometimes in order to do that, we might want to change the signature of a method.
Turns out adding an overload helps in other cases as well.
We used a βsetterβ to expose and inject internal state before. Another option is to add a controllable overload to bypass the internal state.
Letβs look at this code:
public Bool isSameStreet(String newStreet) {
return newStreet == this.currentAddress.getStreet();
}In this example, we compare an external value to an internal state. As we saw before, the option we could use is add a βsetterβ accessor, to allow injecting the internal value from outside. Instead, we can also add an overload:
public Bool isSameStreet(String newStreet) {
return isSameStreet(newStreet, this.currentAddress.getStreet());
}
public Bool isSameStreet(String newStreet, String currentStreet) {
return newStreet == currentStreet();
}We do the actual comparison on the new overload. The new overload should be accessible to the test, depending on language (so it doesnβt have to be completely public). In the original method, we delegate the call to the new implementation.
The new overload is more controllable. We can stop there, but if our logic code does not rely on state anymore, why not use Extract Class?
public Bool isSameStreet(String newStreet) {
return StreetValidator.areEqual(newStreet, this.currentAddress.getStreet());
}The StreetValidator class can now be controlled and tested easily.
Time to wrap up the series. So next time, in the last chapter β using dependency injection framework.
| Reference: | Legacy Code to Testable Code #6: Add Overload from our JCG partner Gil Zilberfeld at the Geek Out of Water blog. |
Thank you!
We will contact you soon.
Gil ZilberfeldOctober 30th, 2014Last Updated: October 29th, 2014

This site uses Akismet to reduce spam. Learn how your comment data is processed.