Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 스터디
- 도메인 주도 개발 시작하기
- 책스터디
- 코틀린
- 클린아키텍처
- 함수형프로그래밍
- Java
- 개발서적
- template
- Boot Legacy 차이점
- TDD
- 객체지향의사실과오해
- Kotlin
- FP
- Thymeleaf
- 테스트
- 헥사고날아키텍처
- 개발방법론
- Spring
- 유지보수
- GrokkingFunctionalProgramming
- DDD
- 만들면서배우는클린아키텍처
- 아키텍처
- 조영호
- web
- 테스트주도개발
- 추상화 설계
- 계층형아키텍처
- 이펙티브코틀린
Archives
- Today
- Total
김동형수 개발기
테스트 주도 개발 - 1부 4장 본문
4장 프라이버시
할일목록
- $5 + 10CHF = $10(환율이 2:1일 경우)
$5 X 2 = $10- amount를 private로 만들기
Dollar 부작용?- Money 반올림?
equals()- hashCode()
- Equal null
- Equal object
Dollar.times() 연산은 결과값을 Dollar 인스턴스를 반환해야 한다.
하지만 테스트가 정확히 그것을 말하지는 않는다.
assertion을 Dollar와 Dollar를 비교하는 것으로 재작성할 수 있다.
임시변수인 product는 제거한다.
변경된 코드에서는 amount필드에 public하게 접근하지 않아서 private로 변경할 수 있다.
할일목록
- $5 + 10CHF = $10(환율이 2:1일 경우)
$5 X 2 = $10amount를 private로 만들기Dollar 부작용?- Money 반올림?
equals()- hashCode()
- Equal null
- Equal object
동치성(equals)테스트가 잘못된 결과를 반환한다면, 곱하기 테스트 또한 잘못된 결과를 반환하고 있을 수 있다.
TDD를 하면서 적극적으로 관리해야할 위험 요소다.
테스트 코드를 명확한 구현을 하면서 작성한 코드들의 다른 테스트에 의존성이 발생한다면 ( 동치성, 곱하기 ) 그것이 TDD의 위험요소라고 이해가 된다.
완벽함을 위해 노력하지 않고
자신감을 가지고 결함의 정도를 낮추기 희망하고
추론이 맞지 않아서 결함이 발생하게 되면 교훈을 얻고 앞으로 나아간다.
지금까지 배운 것
- 오직 테스트를 향상시키기 위해서만 개발된 기능을 사용했다.
- 두 테스트가 동시에 실패하면 망한다는 점을 인식했다.
- 위험 요소가 있음에도 계속 진행한다.
- 테스트와 코드 사이의 결합도를 낮추기 위해, 테스트하는 객체의 새 기능을 사용했다.
'책 스터디 > [완료] 테스트 주도 개발' 카테고리의 다른 글
테스트 주도 개발 - 1부 6장 (0) | 2022.08.30 |
---|---|
테스트 주도 개발 - 1부 5장 (0) | 2022.08.30 |
테스트 주도 개발 - 1부 3장 (0) | 2022.08.30 |
테스트 주도 개발 - 1부 2장 (0) | 2022.08.29 |
테스트 주도 개발 - 1부 1장 (0) | 2022.08.29 |
Comments