Merge branch '5.3.x'

This commit is contained in:
Sam Brannen 2022-05-14 18:32:14 +02:00
commit 754636ee56
1 changed files with 30 additions and 2 deletions

View File

@ -148,25 +148,53 @@ class AnnotationConfigApplicationContextTests {
void nullReturningBeanPostProcessor() {
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext();
context.register(AutowiredConfig.class);
// 1st BPP always gets invoked
context.getBeanFactory().addBeanPostProcessor(new BeanPostProcessor() {
@Override
public Object postProcessBeforeInitialization(Object bean, String beanName) {
if (bean instanceof TestBean) {
TestBean testBean = (TestBean) bean;
testBean.name = testBean.name + "-before";
}
return bean;
}
@Override
public Object postProcessAfterInitialization(Object bean, String beanName) {
if (bean instanceof TestBean) {
TestBean testBean = (TestBean) bean;
testBean.name = testBean.name + "-after";
}
return bean;
}
});
// 2nd BPP always returns null for a TestBean
context.getBeanFactory().addBeanPostProcessor(new BeanPostProcessor() {
@Override
public Object postProcessBeforeInitialization(Object bean, String beanName) {
return (bean instanceof TestBean ? null : bean);
}
@Override
public Object postProcessAfterInitialization(Object bean, String beanName) {
return (bean instanceof TestBean ? null : bean);
}
});
// 3rd BPP never gets invoked with a TestBean
context.getBeanFactory().addBeanPostProcessor(new BeanPostProcessor() {
@Override
public Object postProcessBeforeInitialization(Object bean, String beanName) {
bean.getClass().getName();
assertThat(bean).isNotInstanceOf(TestBean.class);
return bean;
}
@Override
public Object postProcessAfterInitialization(Object bean, String beanName) {
bean.getClass().getName();
assertThat(bean).isNotInstanceOf(TestBean.class);
return bean;
}
});
context.refresh();
TestBean testBean = context.getBean(TestBean.class);
assertThat(testBean).isNotNull();
assertThat(testBean.name).isEqualTo("foo-before-after");
}
@Test