본문 바로가기

테스트24

테스트 코드 개선하기 - 테스트 리팩토링 하기 (+ 예제) 테스트 코드 개선하기 - 테스트 리팩토링 하기 (+ 예제) xUnit 테스트 패턴 - 제라드 메스자로스 - 0장 테스트는 애자일 개발 프로세스에서 금방 병목이 될 수 있다. 간단하고 알기쉬운 테스트와 복잡하고 무디며 유지 보수하기 어려운 테스트는 생산성에서 엄청난 차이가 있다. 예시를 통해 실제적으로 어떻게 테스트 코드를 개선할지에 대한 예시를 같이 알아보자. 복잡한 테스트 최초 코드는 다음과 같다. public void testAddItemQuantity_severalQuantity_v1(){ Address billingAddress = null; Address shippingAddress = null; Customer customer = null; Product product = null; Invoi.. 2023. 9. 26.
테스트는 왜 해야하고 어떻게 해야할까 테스트를 왜 해야하고 어떻게 해야할까? xUnit 테스트 패턴 - 제라드 메스자로스 - 0장 리팩토링 4장에서 마틴 파울러는 다음과 같이 이야기 했다. 프로그래머가 업무 시간을 어떻게 보내는지를 살펴보면 사실 코드를 짜는 시간은 얼마 되지 않는다는 사실을 알게 될 것이다. 뭐가 어덯게 돌아가야 하는지를 찾아보거나 설계를 하기도 하지만 업무 시간의 대부분은 디버깅으로 보낸다. 프로그래머라면 누구나 몇 시간, 아니 밤새 디버깅해본 경험이 있을테고 이런 힘든 디버깅에 대한 무용담쯤은 하나씩 늘어놓을 수 있다. 버그 수정이야 보통 금방이지만 버그 찾기는 죽음이다. 게다가 버그 하나 고치고나면 꼭 다른 버그가 생기기 마련이고, 한참 후에야 그걸 알게 된다. 그러면 또 그 버그를 찾느라 온종일을 날려먹게 된다. 피.. 2023. 9. 26.
xUnit 테스트 패턴 - 소개 xUnit 테스트 패턴 - 제라드 메스자로스 단위 테스트 책을 다 읽었다. 그리고 다음 읽을 책을 이 책으로 정했다. 이 책은 한국어 번역본은 있긴 했는데 절판된 상태라 구하기 어려웠다. 그냥 원문을 구매할까 고민을 많이 하다가 그래도 번역본이 읽는 속도가 빠를것 같아 번역본을 구매하는 방향으로 결정했다. 어렵게 구한만큼 열심히 읽어야겠다 마음먹었다. 기존에 읽던 단위 테스트 책은 C# 인데 xUnit 테스트 패턴 책은 Java 라서 더 기대하고 있다. 본격적으로 시작하기 전에 목차를 통해 이 책에서 어떤 내용을 배울 수 있을지 알아보자. 목차 0부 추천의 글 - 마틴 파울러 저자 소개 들어가며 (테스트 관련 기본 개념) 소개 테스트 리팩토링 1부 설명 1장 간단하게 둘러보기 개요 가장 확실하면서도 간단.. 2023. 9. 24.
단위 테스트 안티 패턴 – 11장 1 비공개 메서드 단위 테스트 비공개 메서드는 어떻게 해야할까? 결론 부터 이야기 하면 '전혀 하지 말아야 한다'. 1.1 비공개 메서드와 테스트 취약성 단위 테스트를 하려고 비공개 메서드를 노출하는 것은 "식별할 수 있는 동작만 테스트 하라" 라는 기본 원칙을 위반한다. 비공개 메서드를 노출하면 테스트가 구현 세부 사항과 결합되고 결과적으로 리팩터링 내성이 덜어진다. 비공개 메서드를 직접 테스트하는 대신, 포괄적인 식별할 수 있는 동작으로서 간접적으로 테스트 하는 것이 좋다. 1.2 비공개 메서드와 불필요한 커버리지 때로는 비공개 메서드가 너무 복잡해서 식별할 수 있는 동작을 일부로 이를 테스트하기에는 충분한 커버리지를 얻을 수 없을 경우가 있다. 식별할 수 있는 동작에 이미 합리적인 테스트 커버리지가.. 2023. 9. 23.
목 처리에 대한 모범 사례 - 9장 9장 목 처리에 대한 모범 사례 단위테스트 (블라디미르 코리코프) 9장에서 다루는 내용 목의 가치를 극대화하기 목을 스파이로 교체하기 목 처리에 대한 모범 사례 목은 테스트 대상 시스템과 의존성 간의 상호 작용을 모방하고 검사 하는 데 도움이 되는 테스트 대역이다. 목은 비관리 의존성(외부 애플리케이션에서 식별할 수 있음)에만 적용해야 한다. 다른 것에 목을 사용하면 깨지기 쉬운 테스트(리팩터링 내성이 없는 테스트)가 된다. 이번 장에서는 목에 대해 리팩터링 내성과 회귀 방지를 최대화해서 최대 가치의 통합 테스트를 개발하는 데 도움이 되는 지침을 마저 알아본다. 먼저 일반적인 목 사용법과 그 단점을 알아보고, 단점을 극복할 수 있는 방법을 살펴본다. 9.1 목의 가치를 극대화하기 비관리 의존성에만 목을 .. 2023. 9. 21.
8장 통합 테스트를 하는 이유 (3) : 언제 인터페이스를 써야할까? + 통합 테스트 작성 팁 8장 통합 테스트를 하는 이유 (3) 단위테스트 (블라디미르 코리코프) 8.4 의존성 추상화를 위한 인터페이스 사용 8.4.1 인터페이스와 느슨한 결합 많은 개발자가 데이터베이스나 메시지 버스와 같은 프로세스 외부 의존성을 위해 인터페이스를 도입한다. 심지어 인터페이스에 구현이 하나만 있는 경우에도 그렇다. 이 관습은 널리 퍼져 있어서 아무도 의문을 제기하지 않는다. 예시는 다음과 같다. public interface ImessageBus public class MessageBus : IMessageBus public interface IUserRepository public class UserRepository : IUserRepository 인터페이스를 사용하는 일반적인 이유 다음과 같다. 프로세스 .. 2023. 9. 15.