Community

개발자 99% 커뮤니티에서 수다 떨어요!

← Go back
클린 코드 TIL : 8장 경계, 9장 단위 테스트
#clean_code
9개월 전
391

오늘 TIL 3줄 요약

  • 생각 / 개념적으로는 대략 이해가 되는데, 실제로 어떻게 적용해야 할지 감이 잘 잡히지 않는다.

    • 예시 / 테스트 코드를 먼저 작성한다??

    • 나를 위한 것인가? 협업을 하는 다른 사람(미래의 나 포함)들 위한 것인가?

  • 책 / 테스트 코드는 실제 코드 못지 않게 중요하다. 테스트 코드는 이류 시민이 아니다. 테스트 코드는 사고와 설계와 주의가 필요하다. 실제 코드 못지 않게 깨끗하게 짜야 한다.

  • 책 / 테스트 코드가 복잡할수록 실제 코드를 짜는 시간보다 테스트 케이스를 추가하는 시간이 더 걸리기 십상이다.

TIL (Today I Learned) 날짜

  • 2024-02-08(목)

오늘 읽은 범위

  • 8장 경계

  • 9장 단위 테스트

책에서 기억하고 싶은 내용을 써보세요.

  • 외부 코드를 익히기는 어렵다. 외부 코드를 통합하기도 어렵다. 두 가지를 동시에 하기는 두 배나 어렵다. 다르게 접근하면 어떨까? 곧바로 우리쪽 코드를 작성해 외부 코드를 호출하는 대신 먼저 간단한 테스트 케이스를 작성해 외부 코드를 익히면 어떨까? 짐 뉴커크는 이를 학습 테스트라 부른다.

  • 학습 테스트에 드는 비용은 없다. 어쩄든 API를 배워야 하므로...... 오히려 필요한 지식만 확보하는 손쉬운 방법이다. 학습 테스트는 이해도를 높여주는 정확한 실험이다.

  • 지금 즈음이면 TDD가 실제 코드를 짜기 전에 단위 테스트부터 짜라고 요구한다는 사실을 모르는 사람은 없으리라. 하지만 이 규칙은 빙산의 일각에 불과하다.다음 세 가지 법칙을 살펴보자.

    • 첫째 법칙: 실패하는 단위 테스트를 작성할 때까지 실제 코드를 작성하지 않는다.

    • 둘째 법칙: 컴파일은 실패하지 않으면서 실행이 실패하는 정도로만 단위 테스트를 작성한다.

    • 셋째 법칙: 현재 실패하는 테스트를 통과할 정도로만 실제 코드를 작성한다.

  • 테스트 코드가 복잡할수록 실제 코드를 짜는 시간보다 테스트 케이스를 추가하는 시간이 더 걸리기 십상이다.

  • 하지만 테스트 슈트가 없으면 개발자는 자신이 수정한 코드가 제대로 도는지 확인할 방법이 없다. 테스트 슈트가 없으면 시스템 이쪽을 수정해도 저쪽이 안전하다는 사실을 검증하지 못한다.

  • 테스트 코드는 실제 코드 못지 않게 중요하다. 테스트 코드는 이류 시민이 아니다. 테스트 코드는 사고와 설계와 주의가 필요하다. 실제 코드 못지 않게 깨끗하게 짜야 한다.

  • 실제 코드를 점검하는 자동화된 단위 테스트 슈트는 설계와 아키텍처를 최대한 깨끗하게 보존하는 열쇠다. 테스트는 유연성, 유지보수성, 재사용성을 제공한다. 테스트 케이스가 있으면 변경이 쉬워지기 때문이다.

  • 깨끗한 테스트 코드를 만들려면? 세 가지가 필요하다. 가독성, 가독성, 가독성. 어쩌면 가독성은 실제 코드보다 테스트 코드에 더더욱 중요하다.

  • 이런 테스트 API는 처음부터 설계된 API가 아니다. 잡다하고 세세한 사항으로 범벋괸 코드를 계속 리팩터링하다가 진화된 API다.

  • 테스트는 적시에 작성해야 한다. 단위 테스트는 테스트하는 실제 코드를 구현하기 직전에 구현한다. 실제 코드를 구현한 다음에 테스트 코드를 만들면 실제 코드가 테스트하기 어렵다는 사실을 발견할지도 모른다.어떤 실제 코드는 테스트하기 너무 어렵다고 판명날지 모른다. 테스트가 불가능하도록 실제 코드를 설계할지도 모른다.

오늘 읽은 소감은? 떠오르는 생각을 가볍게 적어보세요

  • 개념적으로는 대략 이해가 되는데, 실제로 어떻게 적용해야 할지 감이 잘 잡히지 않는다.

    • 테스트 코드를 먼저 작성한다? 어떻게?

      • 게다가 나같은 초보가 테스트 코드를 먼저하려니 먼가 더 복잡하고 어렵게 느껴지기도 한다.

        • 고려해야할게 너무 많아져서 손발이 굳는다.

  • TDD 방법론이나, TDD 적용 프로젝트 예제를 찾아봐야겠다.

궁금한 내용이 있거나, 잘 이해되지 않는 내용이 있다면 적어보세요.

오늘 읽은 다른사람의 TIL