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

권태완님의 프로필 이미지
권태완

작성한 질문수

스프링 핵심 원리 - 기본편

애노테이션 @PostConstruct, @PreDestroy

ac.close method

해결된 질문

작성

·

236

0

아래의 코드 처럼 ApplicationContext로 스프링 컨테이너를 사용해서 스프링 빈의 생명주기를 Test해 보았는데요.
init은 출력이 되었지만 close는 출력되지 안되더라구요.
 
1. Spring을 수동으로 내려 주지 않으면 Spring Bean이 내려갈때 소멸전 콜백은 실행되지 않는건가요?
 
2. ApplicationContext로 실행 했을때는
13:15:33.326 [main] DEBUG org.springframework.context.annotation.AnnotationConfigApplicationContext - Closing org.springframework.context.annotation.AnnotationConfigApplicationContext@53aac487, started on Mon May 02 13:15:33 KST 2022
이와 같은 로그가 뜨지 않았는데 제가 Test로 해서 Spring Container가 내려 가지 않은건가요(Spring이 종료가 되지 않음)?
 
난잡한 변수명 이해부탁 드립니다. 감사합니다.
package hello.core.lab;

import org.junit.jupiter.api.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;

public class SpringClose {

    @org.junit.jupiter.api.Test
    void ContainerClose() {
        ApplicationContext ac = new AnnotationConfigApplicationContext(TestConfig.class);
//        ac.close();
    }

    @Configuration
    static class TestConfig {
        @Bean
        public Test hi() {
            return new Test();
        }
    }

    static class Test {
        @PostConstruct
        public void init() {
            System.out.println("init");
        }

        @PreDestroy
        public void close() {
            System.out.println("close");
        }
    }
}

답변 1

2

안녕하세요. 권태완님, 공식 서포터즈 David입니다.

테스트 내에서 임의로 application context를 생성하신 후 종료하지 않았습니다.

당연히 종료되지 않았기 때문에 @PreDestory가 붙은 메서드가 호출되지 않습니다.

아래와 같이 컨텍스트 종료 메서드를 지원하는 AnnotationConfigApplicationContext 타입으로 객체를 생성하시고 close를 호출해주세요. close가 찍히는 걸 볼 수 있습니다.

AnnotationConfigApplicationContext ac = new AnnotationConfigApplicationContext(TestConfig.class);

ac.close();

아울러 Test 클래스를 만드셨는데, 그러면 @Test를 사용하실 때 패키지 명이 붙게되니 다른 이름을 사용하시면 패키지경로가 붙지 않은 @Test 를 사용할 수 있습니다.

감사합니다.

 

 

권태완님의 프로필 이미지
권태완
질문자

감사합니다!

권태완님의 프로필 이미지
권태완

작성한 질문수

질문하기