Skip to content

Commit 60fa704

Browse files
committed
Consistent behavior for overloaded @bean methods with ASM processing
Closes gh-25263
1 parent f43c39c commit 60fa704

File tree

2 files changed

+52
-7
lines changed

2 files changed

+52
-7
lines changed

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

Lines changed: 14 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -211,7 +211,7 @@ private void loadBeanDefinitionsForBeanMethod(BeanMethod beanMethod) {
211211
return;
212212
}
213213

214-
ConfigurationClassBeanDefinition beanDef = new ConfigurationClassBeanDefinition(configClass, metadata);
214+
ConfigurationClassBeanDefinition beanDef = new ConfigurationClassBeanDefinition(configClass, metadata, beanName);
215215
beanDef.setSource(this.sourceExtractor.extractSource(metadata, configClass.getResource()));
216216

217217
if (metadata.isStatic()) {
@@ -276,7 +276,7 @@ private void loadBeanDefinitionsForBeanMethod(BeanMethod beanMethod) {
276276
new BeanDefinitionHolder(beanDef, beanName), this.registry,
277277
proxyMode == ScopedProxyMode.TARGET_CLASS);
278278
beanDefToRegister = new ConfigurationClassBeanDefinition(
279-
(RootBeanDefinition) proxyDef.getBeanDefinition(), configClass, metadata);
279+
(RootBeanDefinition) proxyDef.getBeanDefinition(), configClass, metadata, beanName);
280280
}
281281

282282
if (logger.isTraceEnabled()) {
@@ -398,24 +398,31 @@ private static class ConfigurationClassBeanDefinition extends RootBeanDefinition
398398

399399
private final MethodMetadata factoryMethodMetadata;
400400

401-
public ConfigurationClassBeanDefinition(ConfigurationClass configClass, MethodMetadata beanMethodMetadata) {
401+
private final String derivedBeanName;
402+
403+
public ConfigurationClassBeanDefinition(
404+
ConfigurationClass configClass, MethodMetadata beanMethodMetadata, String derivedBeanName) {
405+
402406
this.annotationMetadata = configClass.getMetadata();
403407
this.factoryMethodMetadata = beanMethodMetadata;
408+
this.derivedBeanName = derivedBeanName;
404409
setResource(configClass.getResource());
405410
setLenientConstructorResolution(false);
406411
}
407412

408-
public ConfigurationClassBeanDefinition(
409-
RootBeanDefinition original, ConfigurationClass configClass, MethodMetadata beanMethodMetadata) {
413+
public ConfigurationClassBeanDefinition(RootBeanDefinition original,
414+
ConfigurationClass configClass, MethodMetadata beanMethodMetadata, String derivedBeanName) {
410415
super(original);
411416
this.annotationMetadata = configClass.getMetadata();
412417
this.factoryMethodMetadata = beanMethodMetadata;
418+
this.derivedBeanName = derivedBeanName;
413419
}
414420

415421
private ConfigurationClassBeanDefinition(ConfigurationClassBeanDefinition original) {
416422
super(original);
417423
this.annotationMetadata = original.annotationMetadata;
418424
this.factoryMethodMetadata = original.factoryMethodMetadata;
425+
this.derivedBeanName = original.derivedBeanName;
419426
}
420427

421428
@Override
@@ -431,7 +438,8 @@ public MethodMetadata getFactoryMethodMetadata() {
431438

432439
@Override
433440
public boolean isFactoryMethod(Method candidate) {
434-
return (super.isFactoryMethod(candidate) && BeanAnnotationHelper.isBeanAnnotated(candidate));
441+
return (super.isFactoryMethod(candidate) && BeanAnnotationHelper.isBeanAnnotated(candidate) &&
442+
BeanAnnotationHelper.determineBeanNameFor(candidate).equals(this.derivedBeanName));
435443
}
436444

437445
@Override

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

Lines changed: 38 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright 2002-2019 the original author or authors.
2+
* Copyright 2002-2020 the original author or authors.
33
*
44
* Licensed under the Apache License, Version 2.0 (the "License");
55
* you may not use this file except in compliance with the License.
@@ -280,12 +280,32 @@ public void configurationWithApplicationListener() {
280280
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();
281281
ctx.register(ConfigWithApplicationListener.class);
282282
ctx.refresh();
283+
283284
ConfigWithApplicationListener config = ctx.getBean(ConfigWithApplicationListener.class);
284285
assertThat(config.closed).isFalse();
285286
ctx.close();
286287
assertThat(config.closed).isTrue();
287288
}
288289

290+
@Test
291+
public void configurationWithOverloadedBeanMismatch() {
292+
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();
293+
ctx.registerBeanDefinition("config", new RootBeanDefinition(OverloadedBeanMismatch.class));
294+
ctx.refresh();
295+
296+
TestBean tb = ctx.getBean(TestBean.class);
297+
assertThat(tb.getLawyer()).isEqualTo(ctx.getBean(NestedTestBean.class));
298+
}
299+
300+
@Test
301+
public void configurationWithOverloadedBeanMismatchWithAsm() {
302+
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();
303+
ctx.registerBeanDefinition("config", new RootBeanDefinition(OverloadedBeanMismatch.class.getName()));
304+
ctx.refresh();
305+
306+
TestBean tb = ctx.getBean(TestBean.class);
307+
assertThat(tb.getLawyer()).isEqualTo(ctx.getBean(NestedTestBean.class));
308+
}
289309

290310

291311
/**
@@ -595,4 +615,21 @@ public ApplicationListener<ContextClosedEvent> listener() {
595615
}
596616
}
597617

618+
619+
@Configuration
620+
public static class OverloadedBeanMismatch {
621+
622+
@Bean(name = "other")
623+
public NestedTestBean foo() {
624+
return new NestedTestBean();
625+
}
626+
627+
@Bean(name = "foo")
628+
public TestBean foo(@Qualifier("other") NestedTestBean other) {
629+
TestBean tb = new TestBean();
630+
tb.setLawyer(other);
631+
return tb;
632+
}
633+
}
634+
598635
}

0 commit comments

Comments
 (0)