1. 책의 예제
1) 코드 초안
- 모든 로직이 하나의 클래스에 들어가 있다.
- 처음부터 지저분한 코드를 짜려는 생각은 없었고, 코드를 어느정도 손봤지만, 새로운 인수 유형이 들어오면서 재앙이 시작됐다.
- 이제는 개선해야 할 때라는 것을 깨닫고, 변경 전후 시스템이 동일하게 돌아간다는 사실을 확인하기 위해 테스트들을 작성해뒀다.
- 자잘하게 점진적으로 개선해나갔다.
2) 코드 완성본
- Args 클래스에서 코드 중복을 최소화하고, ArgsException 클래스를 분리했다. ArgumentMarshaler 클래스를 통해 여러 인수에 대한 추후 확장성을 만들어냈다.
- 코드만 분리해도 설계가 좋아진다. 관심사를 분리하면 코드를 이해하고 보수하기 훨씬 더 쉬워진다.
2. 점진적으로 개선하기
- 코드가 나빠지고 있음을 느꼈을 때 기능을 추가하지 않고 개선을 시작한다.
- 테스트 코드를 작성한다.
- 변경을 가한 후에도 시스템이 변경 전과 똑같이 돌아가야 한다. 테스트 코드가 없다면 작성하고, 코드를 수정하기 전 상태에서 모든 테스트가 통과해야 한다.
- 점진적으로 개선한다.
- 책임에 따라 클래스를 나누고, 코드를 옮긴다. 테스트가 깨지지 않도록 확인하며 자잘한 변경을 조금씩 진행한다.
3. IDE를 활용해 점진적으로 개선하기
참고자료 : https://github.com/cheese10yun/IntelliJ/blob/master/nomal/refactoring.md