세상을 바꾸는 개발자

출력기반, 상태기반, 통신기반의 테스트 스타일 본문

기타/UnitTest

출력기반, 상태기반, 통신기반의 테스트 스타일

헬창코딩 2022. 4. 25. 12:44

하나의 테스트에서 3가지 스타일을 모두 사용이 가능

  • 출력기반의 테스트 정의(가장 선호해야한다.)
    • 입력을 넣고 출력을 검증하는 방식
    • 전역상태나 내부 상태를 변경하지 않는 코드에만 적용되므로 반환 값만 검증하면 됨
    • 함수형 프로그램에 뿌리를 두고있음(함수형으로 작성된 코드에만 적용가능)
    • 테스트 대상 메서드에만 결합되므로 거짓 양성방지가 가장 우수(리팩터링 내성 가장우수)
    • 유지비 가장 낮음
  • 상태 기반 스타일 정의
    • 작업이 완료된 후 시스템 상태를 확인하는 것(상태는 SUT, 협력자중 하나)
  • 통신 기반 스타일 정의
    • 목을 사용해서 테스트 대상 시스템과 협력자 간의 통신을 검증
    • 유지비 가장 높음
고전파는 통신기반 스타일보다는 상태기반 런던파는 이와 반대 하지만 두분파는 출력 기반 테스트를 사용

함수형 아키텍처 vs 숨은 입출력

  • 함수형 프로그래밍이란
    • 수학적 함수(순수함수)를 사용한 프로그래밍
    • 수학적함수란 숨은 입출력이 없는 함수(p.196)
    • 목표 : 부작용을 완전히 제거하는 것이 아니라 비즈니스 로직을 처리하는 코드와 부작용을 일으키는 코드를 분리하는 것
  • 숨은 입출력
    • 부작용 : 메서드 시그니처에 표시되지않은 출력(숨어있음)
    • 예외
    • 내외부 상태에 대한 참조

비즈니스로직과 부작용을 분리

  • 결정을 내리는 코드(함수형 코어)
    • 부작용이 필요 없어서 수학적 함수를 사용해 작성
  • 해당 결정에 따라 작용하는 코드(가변 셸)
    • 수학적 함수에 의해 이뤄진 모든 결정을 가시적인 부분으로 변환
    • 가능한 아무말도 하지 않아야한다.

함수형 아키텍처의 단점

  • 항상 함수형 아키텍처를 이루기 힘듬
  • 코드베이스가 커지고 성능에 영향을 미치면서 유지 보수성의 이점이 상쇄
  • 유지보수성의 향상을 위해 성능을 희생시킨다.
  • 모든 코드베이스를 함수형 아키텍처로 전환이 불가함 → 전략적으로 사용해야함
  • (코드가 단순하거나 중요하지 않으면 별 효과x )

 

혼자 단위테스트라는 책을 읽으면서 생각에 흐름대로 적은 글입니다..
참고한 책은 단위 테스트라는 책입니다. ( http://www.yes24.com/Product/Goods/104084175 )

Comments