Use bean-creating factory's AutowireCandidateResolver even for dependencies in parent factory
Specifically, if the current factory has Qualifier/ContextAnnotationAutowireCandidateResolver set up, it is important to pass it on to ancestor factories to get consistent qualifier matching results. Issue: SPR-10966
This commit is contained in:
@@ -16,14 +16,12 @@
|
||||
|
||||
package org.springframework.beans.factory.xml;
|
||||
|
||||
import static java.lang.String.format;
|
||||
import java.lang.annotation.ElementType;
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
import java.lang.annotation.Target;
|
||||
import java.util.Properties;
|
||||
|
||||
import static org.junit.Assert.*;
|
||||
import org.junit.Test;
|
||||
|
||||
import org.springframework.beans.factory.BeanCreationException;
|
||||
@@ -31,8 +29,13 @@ import org.springframework.beans.factory.FactoryBean;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.beans.factory.annotation.Qualifier;
|
||||
import org.springframework.beans.factory.annotation.QualifierAnnotationAutowireCandidateResolver;
|
||||
import org.springframework.beans.factory.support.AutowireCandidateQualifier;
|
||||
import org.springframework.beans.factory.support.BeanDefinitionReader;
|
||||
import org.springframework.beans.factory.support.GenericBeanDefinition;
|
||||
import org.springframework.context.support.StaticApplicationContext;
|
||||
|
||||
import static java.lang.String.format;
|
||||
import static org.junit.Assert.*;
|
||||
import static org.springframework.util.ClassUtils.*;
|
||||
|
||||
/**
|
||||
@@ -74,6 +77,31 @@ public final class QualifierAnnotationTests {
|
||||
assertEquals("Larry", person.getName());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testQualifiedByParentValue() {
|
||||
StaticApplicationContext parent = new StaticApplicationContext();
|
||||
GenericBeanDefinition parentLarry = new GenericBeanDefinition();
|
||||
parentLarry.setBeanClass(Person.class);
|
||||
parentLarry.getPropertyValues().add("name", "ParentLarry");
|
||||
parentLarry.addQualifier(new AutowireCandidateQualifier(Qualifier.class, "parentLarry"));
|
||||
parent.registerBeanDefinition("someLarry", parentLarry);
|
||||
GenericBeanDefinition otherLarry = new GenericBeanDefinition();
|
||||
otherLarry.setBeanClass(Person.class);
|
||||
otherLarry.getPropertyValues().add("name", "OtherLarry");
|
||||
otherLarry.addQualifier(new AutowireCandidateQualifier(Qualifier.class, "otherLarry"));
|
||||
parent.registerBeanDefinition("someOtherLarry", otherLarry);
|
||||
parent.refresh();
|
||||
|
||||
StaticApplicationContext context = new StaticApplicationContext(parent);
|
||||
BeanDefinitionReader reader = new XmlBeanDefinitionReader(context);
|
||||
reader.loadBeanDefinitions(CONFIG_LOCATION);
|
||||
context.registerSingleton("testBean", QualifiedByParentValueTestBean.class);
|
||||
context.refresh();
|
||||
QualifiedByParentValueTestBean testBean = (QualifiedByParentValueTestBean) context.getBean("testBean");
|
||||
Person person = testBean.getLarry();
|
||||
assertEquals("ParentLarry", person.getName());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testQualifiedByBeanName() {
|
||||
StaticApplicationContext context = new StaticApplicationContext();
|
||||
@@ -222,6 +250,17 @@ public final class QualifierAnnotationTests {
|
||||
}
|
||||
|
||||
|
||||
private static class QualifiedByParentValueTestBean {
|
||||
|
||||
@Autowired @Qualifier("parentLarry")
|
||||
private Person larry;
|
||||
|
||||
public Person getLarry() {
|
||||
return larry;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
private static class QualifiedByBeanNameTestBean {
|
||||
|
||||
@Autowired @Qualifier("larryBean")
|
||||
|
||||
Reference in New Issue
Block a user