C#/단위테스트

[C# 단위테스트] 단위테스트 목표

범범조조 2021. 11. 22. 21:11

참조

  • 단위 테스트 생산성과 품질을 위한 단위 테스트 원칙과 패턴


단위 테스트 현황

  • 실무에서 단위테스트는 필수로 자리를 잡았습니다.
  • 대부분의 프로그래머는 단위 테스트를 실천하고 중요성에 대해 인지합니다.
  • 단위테스트는 더 이상 논쟁거리가 아니고 그냥 써야 하는 것입니다.


단위 테스트의 목표

  • 흔히 단위 테스트 활동이 더 나은 설계로 이어진다고 생각합니다.
  • 이는 사실입니다. 코드 베이스에 대해 단위 테스트 작성이 필요하면 일반적으로 더 나은 설계로 이러집니다.
  • 하지만 단위 테스트의 주 목표는 아닙니다. 더 나은 설계는 단지 좋은 부수 효과일 뿐입니다.
  • 단위 테스트의 목표는, 소프트웨어 프로젝트의 지속 가능한 성장을 가능하게 하는 것입니다.
  • 지속성과 확장성이 핵심이며, 이를 통해 장기적으로 개발 속도를 유지할 수 있습니다.


좋은 테스트와 좋지 않은 테스트를 가르는 요인

  • 지속 가능한 프로젝트 성장을 위해서는 고품질 테스트에만 집중해야 합니다.
  • 고품질 테스트만이 테스트 스위트에 남을 만한 테스트 유형입니다.


단위 테스트에서 커버리지 지표란?

  • 커버리지 지표는 좋은 부정 지표이지만 나쁜 긍정 지표도 뜻합니다.
  • 커버리지 숫자가 낮으면 문제 징후라 할 수 있습니다.
  • 코드베이스에 테스트되지 않은 코드가 많다는 뜻입니다.
  • 그러나 높은 숫자도 별 의미는 없습니다.
  • 그러므로 코드 커버리지를 측정하는 것은 품질 테스트 스위트로 가는 첫 걸음 이라고 생각하면 됩니다.


정리

  • 코드는 점점 나빠지는 경향이 있다. 지속적인 정리와 리팩터링 등과 같은 적절한 관리가 없으면 시스템은 점점 더 복잡해지고 흐트러집니다.
  • 단위 테스트를 작성하는 것이 중요합니다.
  • 단위 테스트의 목표는 소프트웨어 프로젝트가 지속적으로 성장하게 하는 것입니다.
  • 모든 테스트를 똑같이 작성할 필요는 없습니다.
  • 단위 테스트 코드 기능은 좋은 리트머스 시험이지만, 한 방향으로만 작동합니다. 좋은 부정 지표이지만 나쁜 긍정 지표이기도 합니다.
  • 성공적인 테스트 스위트는 다음과 같습니다.
    • 개발 주기에 통합돼 있다.
    • 코드베이스 중 가장 중요한 부분만을 대상으로 합니다.
    • 최소한의 유지비로 최대의 가치를 끌어냅니다.
728x90