토비님이 생각하시는 단위 테스트, 통합 테스트의 범위를 알려주실 수 있으신가요?
강의에서 말씀하신대로, 단위테스트 혹은 통합테스트와 같은 용어들이 단어가 느슨하게 정의되어 있어 블로그, 책, 강의마다 설명들이 다 달라서 면접 같은 곳에서 질문을 받으면 매우 곤란한데요. 단위 테스트, 통합 테스트 범위? 정의? 같은 것에 대한 토비님의 개인적인 의견 혹은 기준이 궁금합니다.
답변 1
12
제 의견은 사실 중요하지 않습니다. ^^;
저는 단위 테스트는 그냥 하나의 단위(이게 뭔가가 사실 핵심입니다만)를 테스트 하고, 매우 빠르게 수행할 수 있는 테스트다라고만 이야기 하고 있습니다.
단위 테스트는 클래스 한 개만 대상이어야 하고, 그 클래스가 사용하는 의존 오브젝트는 죄다 mock으로 만들어야 한다는 극단적인 의견을 가진 분들도 있습니다. 반면에 하나 이상이더라도 어떤 기능을 수행하는 단위로 묶일 수 있다면 여러개의 클래스를 묶어서 동작하는 것을 테스트 할 수 있다고 보기도 하죠. 켄트 벡은 UI 기준으로 하나의 작업을 단위라고 볼 수도 있다고 했습니다.
저는 DB나 외부 리소스가 사용되는 경우, 설령 임베디드 DB를 쓰거나 롤백 테스트로 만들어서 테스트가 상대적으로 빠르게 동작하고, 테스트간 영향을 주지 않고 고립된 테스트가 가능하다고 해도, 이건 통합 테스트라고 이야기 합니다. 어떤 분들은 하나의 기능을 외부 리소스를 안전하고 빠르게 사용해서 테스트 하면 단위 테스트라고 할 수도 있겠죠. 근데 그게 500ms가 걸리는지 10ms가 걸리는지는 실제 개발하면서 자주 테스트를 수행하는데 상당한 영향을 주기 때문에, 정말 빠른 테스트가 어렵다면 얘는 통합 테스트라고 봅니다. 이건 제 기준입니다.
당연히 두 개 이상의 단위를 묶어서 테스트하면 통합 테스트겠죠. 하지만 단위 테스트에 대한 기준이 사람들마다 달라서 어떤 사람들의 단위 테스트는 다른 사람들의 통합 테스트일 수도 있습니다.
이런 다양한 의견에 대해서 한번쯤 정리해두시고, 그걸 풀어서 설명하고, 자신은 어떤 기준으로 단위테스트를 만들고 수행할 것이고, 내가 선택한 방법의 장점은 어떤 것이다라고 말씀하시면 면접에서는 충분하지 않을까 싶습니다.
단위 테스트에 대해서 더 깊이 살펴보시려면 "단위 테스트 생산성과 품질을 위한 단위 테스트 원칙과 패턴"라는 책을 보시기를 추천드립니다. 관련된 여러가지 의견 차이나 이슈들을 상당히 잘 다룬 책입니다. 그리고 테스트를 어떻게 만들어야 가치가 있을지에 대해서도 깊이 있는 의견과 아이디어를 얻으실 수 있습니다.
11강에서 cmd에서 spring shell에 $ init 하면 Fail 메세지
0
75
2
TestRestTemplate 을 통해 테스트 실행시 웹 요청 정보가 콘솔에 표시되지 않습니다.
0
85
1
섹션7. 자동구성 정보파일분리 강의 질문(@MyAutoConfiguration 붙힌 이유)
0
201
2
WebApplicationContext를 DispatcherServlet에 this로 넘기는 것
0
279
2
인프라 빈 구성 정보의 분리에서 EnableMyAutoConfiguration 질문드립니다.
0
210
2
질문드립니다.
0
232
2
spring boot 3.3.7로 학습중입니다.
0
369
2
Serverproperties 객체 생성 후 @Impor 어노테이션 사용 이유 용도
0
162
2
spring start io 에서 이제더이상 2.x버전은 지원하지 않는 것 같습니다.
1
296
2
Springboot 3.2 이상에서 파라미터 추론관련
0
913
4
binding error
0
220
3
Arrays.copyOf 메서드의 타입 세이프
1
155
2
MyOnClassCondition에 있는 matches method의 Invoke 횟수
1
233
3
인용구의 출처가 궁금합니다.
0
259
1
프로퍼티 빈의 후처리기 도입 AnnotationUtils의 사용
0
236
2
SimpleCacheConfiguration과 빈 등록
0
168
2
MyAutoConfigImportSelector 에서 생성자로 ClassLoader를 주입받을 수 있는 점
0
244
1
IntelliJ project jenerator spring initailizr
0
150
1
강의 자료 레퍼지토리에 업로드
0
216
1
강의자료
0
388
1
Hikari 라이브러리가 없으면 오류가 나는거 아닌가요
0
314
2
Tomcat 포트 프로퍼티 미설정시 랜덤 포트 설정 문의
0
476
5
@Import 로 Bean을 등록해야하는 기준이 뭔지 궁금합니다.
0
340
2
application.properties파일내 프로퍼티 이름
0
210
1





