Legacy Code Change Algorithm

When working with legacy code, it is very easy to get carried away and make a big bang refactoring (actually, 'code cleanup and pray' is a better term since we do not have any tests). In this case, we can try to eliminate the static cling by making the static method non static, and extracting the non-static method into an interface. Make the clients (all the call sites) use the interface. This would mean that we deal with potentially a few changes to the client code to a few hundreds in some worst case scenarios, all at one time. The result could be 'Object Reference not set to an instance of an object'. We want to be able to make this change in a phased manner in small manageable increments.

Approach

  1. Pick one call site.
  2. Change in one call site.
  3. Bring it under the safety net of unit tests.
  4. Make sure the change works.
  5. Meanwhile, the other call sites continue using the original unchanged code and continue to work fine.
  6. Go back to step 1 till all the call sites are refactored, and remove the static method finally.
Let us see how these steps map to one of the techniques in eliminating static cling, 'Introduce instance delegator - p369, Working Effectively with Legacy Code'.

Introduce Instance Delegator

  1. If the class which contains the static method is static, make it non static.
  2. Introduce an instance method with the same signature which delegates to the static method.
  3. Use ExtractInterface and extract the instance method created.
  4. At the call site for the static method, change to use the instance method (called through the extracted interface) instead of the static method.
  5. The instance can be provided at the call site
    • as a parameter
    • via setter injection
    • via constructor injection
Most importantly, the other call sites continue using the static method till we get them under the safety net of unit tests.

Comments

Popular posts from this blog

Navigating the Jungle of Web Traffic: A Technical Team Lead's Guide to "I'm a Celebrity, Get Me Out of Here"

Don’t Look Back in Anger: Mastering the Art of High-Demand Ticketing Events

The Vital Importance of Secure Wi-Fi Networks