Browse Source

Consistent behavior for overloaded @Bean methods with ASM processing

Closes gh-25263
pull/25798/head
Juergen Hoeller 6 years ago
parent
commit
60fa704f78
  1. 20
      spring-context/src/main/java/org/springframework/context/annotation/ConfigurationClassBeanDefinitionReader.java
  2. 39
      spring-context/src/test/java/org/springframework/context/annotation/configuration/ConfigurationClassProcessingTests.java

20
spring-context/src/main/java/org/springframework/context/annotation/ConfigurationClassBeanDefinitionReader.java

@ -211,7 +211,7 @@ class ConfigurationClassBeanDefinitionReader {
return; return;
} }
ConfigurationClassBeanDefinition beanDef = new ConfigurationClassBeanDefinition(configClass, metadata); ConfigurationClassBeanDefinition beanDef = new ConfigurationClassBeanDefinition(configClass, metadata, beanName);
beanDef.setSource(this.sourceExtractor.extractSource(metadata, configClass.getResource())); beanDef.setSource(this.sourceExtractor.extractSource(metadata, configClass.getResource()));
if (metadata.isStatic()) { if (metadata.isStatic()) {
@ -276,7 +276,7 @@ class ConfigurationClassBeanDefinitionReader {
new BeanDefinitionHolder(beanDef, beanName), this.registry, new BeanDefinitionHolder(beanDef, beanName), this.registry,
proxyMode == ScopedProxyMode.TARGET_CLASS); proxyMode == ScopedProxyMode.TARGET_CLASS);
beanDefToRegister = new ConfigurationClassBeanDefinition( beanDefToRegister = new ConfigurationClassBeanDefinition(
(RootBeanDefinition) proxyDef.getBeanDefinition(), configClass, metadata); (RootBeanDefinition) proxyDef.getBeanDefinition(), configClass, metadata, beanName);
} }
if (logger.isTraceEnabled()) { if (logger.isTraceEnabled()) {
@ -398,24 +398,31 @@ class ConfigurationClassBeanDefinitionReader {
private final MethodMetadata factoryMethodMetadata; private final MethodMetadata factoryMethodMetadata;
public ConfigurationClassBeanDefinition(ConfigurationClass configClass, MethodMetadata beanMethodMetadata) { private final String derivedBeanName;
public ConfigurationClassBeanDefinition(
ConfigurationClass configClass, MethodMetadata beanMethodMetadata, String derivedBeanName) {
this.annotationMetadata = configClass.getMetadata(); this.annotationMetadata = configClass.getMetadata();
this.factoryMethodMetadata = beanMethodMetadata; this.factoryMethodMetadata = beanMethodMetadata;
this.derivedBeanName = derivedBeanName;
setResource(configClass.getResource()); setResource(configClass.getResource());
setLenientConstructorResolution(false); setLenientConstructorResolution(false);
} }
public ConfigurationClassBeanDefinition( public ConfigurationClassBeanDefinition(RootBeanDefinition original,
RootBeanDefinition original, ConfigurationClass configClass, MethodMetadata beanMethodMetadata) { ConfigurationClass configClass, MethodMetadata beanMethodMetadata, String derivedBeanName) {
super(original); super(original);
this.annotationMetadata = configClass.getMetadata(); this.annotationMetadata = configClass.getMetadata();
this.factoryMethodMetadata = beanMethodMetadata; this.factoryMethodMetadata = beanMethodMetadata;
this.derivedBeanName = derivedBeanName;
} }
private ConfigurationClassBeanDefinition(ConfigurationClassBeanDefinition original) { private ConfigurationClassBeanDefinition(ConfigurationClassBeanDefinition original) {
super(original); super(original);
this.annotationMetadata = original.annotationMetadata; this.annotationMetadata = original.annotationMetadata;
this.factoryMethodMetadata = original.factoryMethodMetadata; this.factoryMethodMetadata = original.factoryMethodMetadata;
this.derivedBeanName = original.derivedBeanName;
} }
@Override @Override
@ -431,7 +438,8 @@ class ConfigurationClassBeanDefinitionReader {
@Override @Override
public boolean isFactoryMethod(Method candidate) { public boolean isFactoryMethod(Method candidate) {
return (super.isFactoryMethod(candidate) && BeanAnnotationHelper.isBeanAnnotated(candidate)); return (super.isFactoryMethod(candidate) && BeanAnnotationHelper.isBeanAnnotated(candidate) &&
BeanAnnotationHelper.determineBeanNameFor(candidate).equals(this.derivedBeanName));
} }
@Override @Override

39
spring-context/src/test/java/org/springframework/context/annotation/configuration/ConfigurationClassProcessingTests.java

@ -1,5 +1,5 @@
/* /*
* Copyright 2002-2019 the original author or authors. * Copyright 2002-2020 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -280,12 +280,32 @@ public class ConfigurationClassProcessingTests {
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext(); AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();
ctx.register(ConfigWithApplicationListener.class); ctx.register(ConfigWithApplicationListener.class);
ctx.refresh(); ctx.refresh();
ConfigWithApplicationListener config = ctx.getBean(ConfigWithApplicationListener.class); ConfigWithApplicationListener config = ctx.getBean(ConfigWithApplicationListener.class);
assertThat(config.closed).isFalse(); assertThat(config.closed).isFalse();
ctx.close(); ctx.close();
assertThat(config.closed).isTrue(); assertThat(config.closed).isTrue();
} }
@Test
public void configurationWithOverloadedBeanMismatch() {
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();
ctx.registerBeanDefinition("config", new RootBeanDefinition(OverloadedBeanMismatch.class));
ctx.refresh();
TestBean tb = ctx.getBean(TestBean.class);
assertThat(tb.getLawyer()).isEqualTo(ctx.getBean(NestedTestBean.class));
}
@Test
public void configurationWithOverloadedBeanMismatchWithAsm() {
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();
ctx.registerBeanDefinition("config", new RootBeanDefinition(OverloadedBeanMismatch.class.getName()));
ctx.refresh();
TestBean tb = ctx.getBean(TestBean.class);
assertThat(tb.getLawyer()).isEqualTo(ctx.getBean(NestedTestBean.class));
}
/** /**
@ -595,4 +615,21 @@ public class ConfigurationClassProcessingTests {
} }
} }
@Configuration
public static class OverloadedBeanMismatch {
@Bean(name = "other")
public NestedTestBean foo() {
return new NestedTestBean();
}
@Bean(name = "foo")
public TestBean foo(@Qualifier("other") NestedTestBean other) {
TestBean tb = new TestBean();
tb.setLawyer(other);
return tb;
}
}
} }

Loading…
Cancel
Save