본문 바로가기
프로그래밍언어 & 프레임워크/스프링(Spring)

[테코톡] TDD와 단위테스트

by 공부하는개미 2022. 3. 17.
반응형

 

📚 참고자료

  • 유튜브 채널 [우아한 Tect] - 10분 테코톡 피카의 TDD와 단위 테스트

https://www.youtube.com/watch?v=3LMmPXoGI9Q 

 


 

🤔 TDD란?

 

프로그램을 작성하기 전에 테스트를 먼저 하라!

- 켄트 백 Kent Beck -

 

  • TDD (Test-Driven Development)
  • 테스트 코드를 먼저 만들고, 실제 프로덕션 코드를 나중에 만드는 개발 방법을 말합니다.

 

 

 

기존 프로세스

 

 

TDD 방식 프로세스

 

 

 

🤔 TDD를 사용하는 이유는?

  • 변화에 대한 두려움을 줄여준다. (리팩터링이 편하다)
  • 디버깅 시간을 줄여준다.
  • 동작하는 문서 역할을 한다.

 

 

 

😀 TDD의 장점

  • TDD를 하면 자연스레 테스트 커버리지가 높아진다.
  • 오버 엔지니어링을 방지할 수 있다.
    • TDD를 하면서 요구사항에 맞춰 개발 코드를 구현
    • 미래에 필요할 것 같은 구현을 지레짐작하여 불필요한 코드를 작성하는 소요가 줄어든다.
  • 설계에 대한 피드백이 빠르다.
    • 설계를 처음부터 잘한다면 좋겠지만 잘못 설계했다면, 변경이 일어나거나 사용하기 어려울 때 깨달을 수 있다.
      반면에 TDD는 설계에 대한 피드백을 빠르게 해 줄 수 있다.
    • 설계가 복잡해지면 테스트 코드를 작성하기 점점 더 어려워진다.

 

 

😅 TDD의 오해

  • TDD는 실제 방법론이다?
    • TDD는 높은 응집을 유도하지 않는다.
    • TDD는 단일 책임 원칙과 인터페이스 분리 원칙 위배에 어떤 신호도 주지 않는다.
    • TDD는 인터페이스 일관성을 도출하지 않는다.
    • TDD의 리팩터링 단계는 좋은 구조를 안내하거나 좋은 구조를 갖도록 강제하지 않는다.

 

 

 

😥 TDD를 실패하는 이유

  • 코드가 이루고자 하는 가치나 기능을 테스트하기보다 그 기능을 어떻게 구현하고 있는지를 테스트한다.
  • 결국 테스트 케이스들이 구현체와 결합도가 높아진다.
  • 구현체들을 리팩터링 하면 결합되어있는 테스트 케이스들이 모두 깨져버린다.

 

 

 

 

📏 테스트의 범위

 

  • 통합 테스트: 여러 작업 단위가 연계된 워크플로우를 테스트하기
    위한 수단(객체 간, 시스템 간)
  • 기능 테스트: 공개된 API의 가장 바깥쪽에 해당하는 코드 검사
    (Controller 호출, Security, http)
  • 부하 테스트: 주어진 단위 시간 동안 애플리케이션이 얼마나 많은
    요청을 처리할 수 있는지 검사
  • 인수 테스트: 고객 또는 대리인이 정의된 모든 목적에 부합되는지
    확인해보고자 하는 검사

 

 

 

 

 

👍 좋은 단위 테스트

 

F.I.R.S.T 법칙

F - Fast(빠르게)

I - Independent(독립적으로)

R - Repeatable(반복 가능하게)

S - Self-Validating(자가 검증하는)

T - Timely(적시에)

 

 

 


느낀점

  • 설계를 테스트로 검증 한다는 점이 설계에 대한 신뢰성을 더욱 올려줄 것 같습니다.
  • TDD의 장점과 정의는 많지만 어떻게 해야 하는지 아직 감이 안잡히고 있습니다.
    • 이건 TDD 수업을 해주는 교육기관에서 수업을 받아야 할 것 같습니다.
  • TDD는 아니더라도 테스트 코드를 성실하게 작성할 예정입니다.
    • 서비스단 메서드 하나에 하나의 테스트를 작성할 수 있도록 진행

 

 

 

반응형