인프런 커뮤니티 질문&답변

fpg123님의 프로필 이미지

작성한 질문수

Practical Testing: 실용적인 테스트 가이드

테스트 수행도 비용이다. 환경 통합하기

추상클래스 IntegrationTestSupport을 통한 테스트수행 비용단축에 관한 질문

23.07.14 11:57 작성

·

527

1

안녕하세요 강의 테스트 수행도 비용이다. 환경 통합하기 를 듣다가 궁금한 점이 생겨 질문드립니다.

강의에서는 추상클래스 IntegrationTestSupport에 어노테이션 @SpringBootTest을 달아서 통합테스트가 필요한 테스트클래스가 상속하여 스프링컨테이너가 반복 실행되는걸 단축하는게 인상깊었는데요.

원리가 궁금한 점이 있어 질문드립니다.

  1. 어떤 원리로 마치 스프링컨테이너가 전파되듯이 상속받은 클래스로 설정한 컨테이너가 작동하는걸까요?

  2. 그리고 어떻게 상속받은 클래스가 또 실행될 줄 알고 그 환경(컨테이너)가 어느시점까지 종료되지 않고 지속되고 있는건지 궁금합니다

답변 2

0

박우빈님의 프로필 이미지
박우빈
지식공유자

2023. 07. 17. 23:17

안녕하세요, fpg123님! :)

AI 인턴님이 잘 설명을 해주었네요 ㅎㅎ
스프링에서 Bean, Component를 Scan하는 방식을 생각해보시면 도움이 되실 것 같아요.
상속 받은 클래스가 또 실행될 줄 알고 환경을 지속한다기 보다는, 수행 전에 이미 Reflection 등으로 어떤 테스트 클래스들이 상속을 받고 있는지를 확인한 후에 수행이 되는 것이죠.

도움이 되셨기를 바랍니다.
감사합니다. :)

0

인프런 AI 인턴님의 프로필 이미지

2023. 07. 16. 12:01

안녕하세요, 인프런 AI 인턴이에요.
IntegrationTestSupport 추상 클래스는 @SpringBootTest 어노테이션을 사용하여 테스트 클래스가 스프링 컨테이너와 통합 테스트를 수행할 수 있도록 도와줍니다.

IntegrationTestSupport 클래스를 상속받은 테스트 클래스는 @SpringBootTest 어노테이션을 통해 스프링 컨테이너를 설정할 수 있으며, 스프링 컨테이너는 이 테스트 클래스에서 사용되는 빈과 의존성을 미리 로드합니다. 이후에는 테스트 메소드가 실행될 때마다 스프링 컨테이너를 다시 생성하지 않고 이미 로드된 컨테이너를 재사용하는 것이죠.

상속 관계를 통해 스프링 컨테이너가 전파되는 원리는 Java의 상속 특성과 JUnit 테스트 프레임워크가 제공하는 기능을 이용한 것입니다. IntegrationTestSupport 클래스에서 스프링 컨테이너를 띄우고 초기화하는 작업을 수행하고, 이를 상속받은 테스트 클래스에서는 이 작업을 활용하여 추가적인 테스트를 수행할 수 있습니다.

상속 관계에서 상위 클래스가 또한 실행될 줄 아는 이유는 JUnit 프레임워크가 내부적으로 Reflection을 이용해 테스트 클래스의 상속 계층을 분석하고 실행흐름을 제어하기 때문입니다. 따라서 상속 관계에서 테스트 클래스가 실행될 때, 상위 클래스의 설정된 스프링 컨테이너도 같이 실행되게 되는 것이죠.

스프링 컨테이너의 생명주기는 스프링 애플리케이션의 생명주기와 연동됩니다. 보통 스프링 컨테이너는 애플리케이션의 시작 시점에 생성되고, 애플리케이션의 종료 시점에 소멸됩니다. 통합 테스트에서는 테스트 수행 전후로 스프링 컨테이너가 생성되거나 종료되는데, 이는 JUnit의 기능을 이용하여 테스트 실행 전후에 스프링 컨테이너를 생성하거나 종료하는 작업을 추가할 수 있기 때문입니다.

이렇게 상속과 JUnit의 Reflection 기능을 활용하여 IntegrationTestSupport 클래스와 상속받은 테스트 클래스를 통해 스프링 컨테이너의 초기화와 재사용을 구현할 수 있는 것이며, 이를 통해 통합 테스트 수행 시간을 단축할 수 있게 됩니다.

더 자세한 내용은 인프런의 스프링 강의 ‘환경 통합하기’를 참고하세요. 질문이 있으시면 언제든지 물어보세요.
감사합니다.

fpg123님의 프로필 이미지

작성한 질문수

질문하기