Si trata la refactorización como algo propio, más que como parte del proceso de desarrollo, entonces puede llegar a ser interminable.
Si sigue el enfoque de desarrollo basado en pruebas de refactorización rojo, verde, entonces normalmente no tendrá que perder mucho tiempo refactorizando por dos razones:
Estará refactorizando a medida que avanza, por lo que no debería convertirse en una tarea gigantesca, solo otro pequeño paso en el ciclo TDD.
La "presión" interna para obtener la próxima prueba escrita mantendrá sus esfuerzos de refactorización a un nivel razonable.
Si está trabajando con código heredado, siga la "regla de Boy Scout" del tío Bob. Timebox usted mismo a un corto período de tiempo (por ejemplo, 30 minutos) y haga su objetivo de verificar el código en un estado más limpio que antes. Cada vez que tenga que tocar el código, lo dejará un poco mejor. Con el tiempo, el código más modificado será el más legible y mejor factorizado en su código base.