단위 테스트 vs 통합테스트
[ 단위 테스트 ]
단위 테스트는 하나의 모듈을 기준으로 독립적으로 진행되는 가장 작은 단위의 테스트이다.
여기서 모듈은 애플리케이션에서 작동하는 하나의 기능 또는 메소드이다.
ex) 서비스의 다양한 기능 중 로그인 메소드에 대한 독립적인 테스트가 1개의 단위테스트이다.
[ 통합 테스트 ]
통합 테스트는 모듈을 통합하는 과정에서 모듈간의 호환성을 확인하기 위해 수행되는 테스트이다.
애플리케이션은 여러개의 모듈로 이루어져있고, 서로 호출하면서 수행된다.그렇기 때문에 모듈들이 올바르게 연결되어 동작하는지 검증이 필요한데, 이를 위해서 통합테스트가 수행된다.
단위 테스트에 대해
[ 단위 테스트의 필요성 ]
일반적으로 실무에서 테스트 코드를 작성한다고 하면 거의 단위 테스트를 의미한다. 통합 테스트는 실제 여러 컴포넌트들 간의 상호작용을 테스트하기 때문에 모든 컴포넌트들이 구동된 상태에서 테스트를 하게 된다. 그렇기에 통합 테스트를 위해서는 캐시나 데이터베이스 등 다른 컴포넌트들과 실제 연결을 해야 하고, 시스템을 구성하는 컴포넌트들이 많아질수록 테스트를 위한 비용(시간)이 상당히 커진다. 반면에 단위 테스트는 해당 부분만 독립적으로 테스트하기 때문에 어떤 코드를 리팩토링하여도 빠르게 문제 여부를 확인할 수 있다.
좋은 테스트의 특징
- 1개의 테스트 함수에 대해 assert를 최소화하라
-> assert : 단정 메소드로 테스트 케이스의 수행 결과를 판별합니다. - 1개의 테스트 함수는 1가지 개념만을 테스트하라
[ 단위 테스트의 문제점과 Stub ]
어떤 객체가 자체적으로 모든 일을 처리한다면 문제가 없겠지만, 일반적인 애플리케이션에서는 1개의 기능을 처리하기 위해 다른 객체들과 메세지를 주고 받아야 한다. 하지만 앞서 설명하였듯 단위 테스트는 해당 모듈에 대한 독립적인 테스트이기 때문에 다른 객체와 메세지를 주고 받는 경우에 문제가 발생한다. 그렇기 때문에 다른 객체 대신에 가짜 객체(Mock Object)를 주입하여 어떤 결과를 반환하라고 정해진 답변을 준비시켜야 하는데, 이를 stub이라고 한다.
ex) 회원가입 서비스를 테스트할 때, 이메일 중복 확인 서비스에 가짜 서비스를 주입하여 항상 False를 반환하도록 하는 것이 Stub
[ 참고 자료 ]
'JAVA > Spring' 카테고리의 다른 글
@Annotation 정리 (0) | 2022.03.14 |
---|---|
JSP View Resolver 설정 (0) | 2022.03.14 |
@Controller : 요청에 따른 Method 형식과 응답 (0) | 2022.03.14 |
Spring 뷰 폴더 위치 (0) | 2022.03.14 |
HTTP Content-Type (0) | 2022.03.10 |