테스트 코드를 작성하다보면 원 코드의 나쁜 냄새를 맡게해주는 경우가 많다.
테스트를 하면 SOLID가 지켜진다.
- S: 테스트가 너무 많아진다? → 이게 무슨 목적의 클래스지.. 눈에 안들어오는 지점이 생기고 이는 클래스를 분할해야하는 시점임을 알려준다! → 책임이 분배되고 단일 책임 원칙을 지키게 된다.
data:image/s3,"s3://crabby-images/40b83/40b83ed73935a8d213f05b626c9c4e8e646cc702" alt="스크린샷 2023-08-17 오전 12.09.25.png"
data:image/s3,"s3://crabby-images/da979/da979cc3ddd2b4d507ff2c1a73d6fb77f93d3a47" alt="스크린샷 2023-08-17 오전 12.09.44.png"
data:image/s3,"s3://crabby-images/4ba60/4ba6046b3e275dc947ef0fe95c83580cd04f1517" alt="스크린샷 2023-08-17 오전 12.10.29.png"
나쁜 신호
1. 의존성이 숨겨진 경우
data:image/s3,"s3://crabby-images/cdce7/cdce70d15f9f5a0120ee59b6d40130e59da3d612" alt="스크린샷 2023-08-17 오전 12.43.14.png"
data:image/s3,"s3://crabby-images/0d822/0d822a516481aa52c4fd0004b3b7ed7884e42aae" alt="스크린샷 2023-08-17 오전 12.43.59.png"
data:image/s3,"s3://crabby-images/16c8c/16c8cf9df5818b1f8066df855209a7d956ca43e7" alt="스크린샷 2023-08-17 오전 12.46.35.png"
2. Testability가 낮은 경우
- 얼마나 쉽게 input을 변경 가능하고, output을 쉽게 검증할 수 있는가를 보자.
3. private method를 테스트해야하는가?
- NO!
- private method를 테스트하고 싶은 경우라면 private method가 아니어야하던지 다른 클래스로 분리/위임 하라는 신호이다!