Test Double (Swift)
간단 용어 정리
테스트 더블이란, doc와 동일한 API를 제공
- sut (system under test): 테스트 대상
- doc (depended-on component): sut이 의존하고 있는 구성요소
왜 필요할까?
Solitary or Sociable?, 테스트 중인 단위가 Sociable한지 혹은 Solitary인지의 여부가 중요
- Sociable의 경우에 테스트하는 Unit의 결함이 아닌 의존하고 있는 클래스의 결함으로 인해 테스트가 실패하는 문제가 발생할 수 있음
- 이러한 문제를 막기 위해 실제 동작하는 것처럼 보이는 별개의 객체를 따로 만드는 것을 고려할 수 있다.
테스트 더블의 종류
- Dummy: 아무런 동작을 하지 않으며, 인스턴스화 된 객체만 필요하고, 기능까지는 필요하지 않은 경우. Dummy의 값은 테스트의 영향을 미치지 않으며, 단순히 객체가 필요할 때 사용. Dummy의 값에 따라 테스트의 결과다 달라진다면 Stub이나 Mock 등을 고려.
- 아무런 행위를 가지지 않는다.
- Fake: 실제로 동작하는 구현을 갖고 있으나, 프로덕션에서 사용되기 적합하지 않은 객체. 구현된 로직은 존재하나 프로덕션 코드에 비해서 매우 단순한 로직으로 제공. Stub과의 차이점은 로직을 처리한다는 것이다.
- DB를 실제 데이터베이스에 의존하지 않고, 배열 등으로 대체해서 구현할 수 있음.
- Stub: Dummy가 마치 실제로 동작하는 것처럼 보이게 만든 객체. 미리 반환할 데이터가 정의되어 있으며, 메소드를 호출하였을 경우 그것을 그대로 반환하는 역할만 수행, Fake와 닮았으나, Fake는 로직을 구현한다면, Stub은 하드코딩된 상태로 값을 내려보낸다. 상태기반 테스트에 사용. Stub은 인풋에 대한 통제권을 가져오는 것이 목적이며, 리턴하는 값에 대한 검증을 신경쓰지 않는다.
- 하드코딩 된, 혹은 미리 구현된 값들이 들어간다.
- Spy: 실제 객체를 부분적으로 Stubbing하면서 동시에 약간의 정보를 기록하는 객체, 기록하는 정보로는 메소드 호출 여부, 메소드 호출 호출 카운트 등이 포함. 기록한다는 특징 때문에 인풋을 검증할 필요가 있을 때 사용.
- 어떠한 메소드가 호출됨으로써 발생할 수 있는 사이드 이펙트를 조사하기 위해 정보를 기록한다는 개념
- Mock: 호출에 대한 기대를 명세할 수 있고, 그 명세에 따라 동작하도록 프로그래밍된 객체. Mock 외의 것은 개발자가 임의로 코드를 생성하여 사용할 수 있음. Mock은 충분히 Dummy, Stub, Spy처럼 동작할 수 있다. 특정 상황에 대해 의존을 해야하는 경우 등 넓은 범위에서 범용적으로 사용할 수 있다.
경계가 모호한 것 같은데, 아래 이미지 처럼 경계가 명확하기보단 연속적임
Test Double 도입 후기
모듈화가 되어있는 서비스에서 기존에 적용하고 있던 방식이 테스트 더블 방식이었음.
Stub과 Mock이라는 네이밍만 사용했었는데, 조금 더 세분화하여 정의하면 훨씬 좋을 것 같음.
(함께 읽어보면 좋은 글)
https://velog.io/@dlsxor21c/iOS%EC%99%80-Test-double
https://martinfowler.com/bliki/UnitTest.html
https://hudi.blog/test-double/
'apple > Testing, Xcode, Environment' 카테고리의 다른 글
EnableSwiftBuildSystemIntegration (0) | 2023.04.18 |
---|---|
[XCode] Instruments - Network (0) | 2023.04.18 |
[XCTest] XCTest에 대해서 알아보기 1편 (0) | 2022.07.03 |
XCTest Stubber (0) | 2022.02.20 |
[XCTest] RxTest 와 RxBlocking에 대해서 알아보자 (0) | 2022.02.20 |