작성
·
222
0
public class ComponentFilterAppConfigTest {
@Test
void filterScan() {
ApplicationContext ac = new AnnotationConfigApplicationContext(ComponentFilterAppConfig.class);
BeanA beanA = ac.getBean("beanA", BeanA.class);
org.assertj.core.api.Assertions.assertThat(beanA).isNotNull();
Assertions.assertThrows(NoSuchBeanDefinitionException.class, () -> {
ac.getBean("beanB", BeanB.class);
});
}
@Configuration
@ComponentScan(
includeFilters = @ComponentScan.Filter(type = FilterType.ANNOTATION, classes = MyIncludeComponent.class)//,
//excludeFilters = @ComponentScan.Filter(type = FilterType.ANNOTATION, classes = MyExcludeComponent.class)
)
static class ComponentFilterAppConfig {
}
}
안녕하세요 강의잘 보고있습니다. 질문이 여러가지가있는데 우선 첫번째로
저는 처음에 @MyExcludeComponent 위에 Target 과 Retention 옵션으로 스캔이 되나 했는데.. 이건 그냥 메타데이터일 뿐이고
실제로는 @Component 인터페이스만 붙여진 것만 컴포넌트 스캔의 대상이다 가 맞나요??
두번째로 그렇다면 위예제에서 MyExcludeComponent 자체는 사실 컴포넌트 스캔의 대상이아니고 IncludeFilter 에 해당하는 MyIncludeComponent 만 수동등록해준건데.. excludeFilter 를 명시적으로 해주나 안해주나 동일한것 맞나요?? 실제 생략하고 테스트돌려도 동일해서요.
감사합니다.
답변 1
1
안녕하세요. 스프링님
생각하신 내용이 맞습니다. 제가 적절한 예제를 만들지 못했네요.
지금 예제에서는 excludeFilters가 없어도 동일하게 동작합니다.
이 부분을 적절하게 이해하려면 BeanA, BeanB가 모두 @Component를 가지고 있어서 둘다 컴포넌트 스캔의 대상이 될 때 excludeFilters를 넣어주어서 뺄 수 있다 생각하시면 됩니다.
감사합니다.