inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

토비의 스프링 부트 - 이해와 원리

Environment 추상화와 프로퍼티

BooleanCondition 동작 질문

해결된 질문

565

Hello

작성한 질문수 2

0

토비님. 안녕하세요!

다름이 아니라 '스프링부트의 @Conditional' 항목을 공부하던 중에 conditional() 테스트 코드가 어떻게 동작할지 생각해보았습니다. 저는 true과 false가 1번씩 호출될 것이라고 추측을 했었는데, true가 3번이 호출되어서 생각과는 다른 결과를 확인하였습니다.

제가 무언가를 잘못 알고 있는 것 같아서 확인해보고 싶습니다. 어떠한 키워드로 알아보면 이것에 대해서 알 수 있을까요?

 

잘려서 보이지 않는 윗부분의 소스 코드는 강의 내용과 다른 점이 없이 작성되어있습니다.

spring-boot spring spring-jdbc

답변 3

3

토비

조금 더 살펴봤습니다.

일단 컨디션이 false인 경우는 한번만 출력됩니다.

그런데 true인 경우는 처음 한번 출력이 되고 그리고 다음 로그가 나온 뒤에 두 번이 더 출력되네요.

DefaultListableBeanFactory - Creating shared instance of singleton bean 'org.springframework.context.annotation.internalConfigurationAnnotationProcessor'

일단 false 인 경우는 Config2가 아예 빈 생성 대상에서 빠지기 때문에 조건을 한번 체크하고 나서는 더 이상 건드릴 일이 없습니다.

반면 true인 경우는 Config1 클래스 자체가 빈으로 등록이 되고 이후 annotation processor 같은 애노테이션을 다루는 처리기를 거치게 되는데요. 아마 이 작업 중에 컨디션을 다시 체크하는 작업이 두 번 반복적으로 들어가는 것 같습니다. 이게 이미 빈으로 생성된 Config1에 영향을 주는 일은 없지만, 왜 체크하는 기능을 불필요하게 두 번 반복하는지는 더 깊이 내부를 파고 들어가봐야 알 수 있을 것 같습니다.

2

토비

제가 실행을 해봐도 위에 true가 두번 나오고 나서, 원래 기대했던 true, false가 한번씩 찍힙니다.

자동 구성을 테스트하는 ApplicationContextRunner라는 스프링 부트가 제공하는 테스트 도구에서 뭔가 사전 확인이나 캐싱을 위해서 Condition을 콜을 하는 것 같다는 생각이 드는데요. 이건 제가 내부를 좀 더 들여다봐야 알 수 있을 것 같습니다. 좀 더 확인을 해보고 다시 공유해드릴게요.

일단 간단한 Condition을 만들어서 작성한 코드가 기대한대로 동작하는데는 아무 문제는 없습니다.

2

토비

이건 제가 해당 부분 코드를 만들어서 테스트를 해봐야겠네요. 위의 코드만 봐서는 이상한 점은 없습니다.

혹시 이런 현상이 있는 코드 전체를 github 등으로 공유를 해주시면 제가 빠르게 원인을 찾아볼 수 있습니다. 번거로우시면 제가 예상 가능한 원인을 한번 추적해볼게요.

11강에서 cmd에서 spring shell에 $ init 하면 Fail 메세지

0

75

2

TestRestTemplate 을 통해 테스트 실행시 웹 요청 정보가 콘솔에 표시되지 않습니다.

0

85

1

섹션7. 자동구성 정보파일분리 강의 질문(@MyAutoConfiguration 붙힌 이유)

0

201

2

WebApplicationContext를 DispatcherServlet에 this로 넘기는 것

0

279

2

인프라 빈 구성 정보의 분리에서 EnableMyAutoConfiguration 질문드립니다.

0

210

2

질문드립니다.

0

232

2

spring boot 3.3.7로 학습중입니다.

0

369

2

Serverproperties 객체 생성 후 @Impor 어노테이션 사용 이유 용도

0

162

2

spring start io 에서 이제더이상 2.x버전은 지원하지 않는 것 같습니다.

1

296

2

Springboot 3.2 이상에서 파라미터 추론관련

0

913

4

binding error

0

220

3

Arrays.copyOf 메서드의 타입 세이프

1

155

2

MyOnClassCondition에 있는 matches method의 Invoke 횟수

1

233

3

인용구의 출처가 궁금합니다.

0

259

1

프로퍼티 빈의 후처리기 도입 AnnotationUtils의 사용

0

236

2

SimpleCacheConfiguration과 빈 등록

0

168

2

MyAutoConfigImportSelector 에서 생성자로 ClassLoader를 주입받을 수 있는 점

0

244

1

IntelliJ project jenerator spring initailizr

0

150

1

강의 자료 레퍼지토리에 업로드

0

216

1

강의자료

0

388

1

Hikari 라이브러리가 없으면 오류가 나는거 아닌가요

0

314

2

Tomcat 포트 프로퍼티 미설정시 랜덤 포트 설정 문의

0

476

5

@Import 로 Bean을 등록해야하는 기준이 뭔지 궁금합니다.

0

340

2

application.properties파일내 프로퍼티 이름

0

210

1