From 547fc30eadef7fc7d505932ad066c06aafdfa032 Mon Sep 17 00:00:00 2001 From: Jorge Cordoba Date: Mon, 27 Jan 2020 09:41:59 -0700 Subject: [PATCH] Fix condition source in OnBeanCondition See gh-19948 --- .../autoconfigure/condition/OnBeanCondition.java | 7 ++++--- .../condition/ConditionalOnMissingBeanTests.java | 12 ++++++++++++ 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/condition/OnBeanCondition.java b/spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/condition/OnBeanCondition.java index e2287e345537..1f5032967ad2 100644 --- a/spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/condition/OnBeanCondition.java +++ b/spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/condition/OnBeanCondition.java @@ -67,6 +67,7 @@ * @author Jakub Kubrynski * @author Stephane Nicoll * @author Andy Wilkinson + * @author Jorge Cordoba * @see ConditionalOnBean * @see ConditionalOnMissingBean * @see ConditionalOnSingleCandidate @@ -387,7 +388,7 @@ private static class Spec { private final ClassLoader classLoader; - private final Class annotationType; + private final Class annotationType; private final Set names; @@ -581,11 +582,11 @@ Set> getParameterizedContainers() { } ConditionMessage.Builder message() { - return ConditionMessage.forCondition(ConditionalOnBean.class, this); + return ConditionMessage.forCondition(this.annotationType, this); } ConditionMessage.Builder message(ConditionMessage message) { - return message.andCondition(ConditionalOnBean.class, this); + return message.andCondition(this.annotationType, this); } @Override diff --git a/spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/condition/ConditionalOnMissingBeanTests.java b/spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/condition/ConditionalOnMissingBeanTests.java index 9a24b37c29a8..7013b87983fb 100644 --- a/spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/condition/ConditionalOnMissingBeanTests.java +++ b/spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/condition/ConditionalOnMissingBeanTests.java @@ -21,6 +21,7 @@ import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; +import java.util.Collection; import java.util.Date; import java.util.function.Consumer; @@ -57,6 +58,7 @@ * @author Phillip Webb * @author Jakub Kubrynski * @author Andy Wilkinson + * @author Jorge Cordoba */ @SuppressWarnings("resource") public class ConditionalOnMissingBeanTests { @@ -135,6 +137,16 @@ void testAnnotationOnMissingBeanConditionWithEagerFactoryBean() { assertThat(context.getBean("foo")).isEqualTo("foo"); }); } + @Test + void testOnMissingBeanConditionOutputShouldNotContainConditionalOnBeanClassInMessage() { + this.contextRunner.withUserConfiguration(ConditionalOnMissingBeanTests.OnBeanNameConfiguration.class).run((context) -> { + Collection conditionAndOutcomes = ConditionEvaluationReport + .get(context.getSourceApplicationContext().getBeanFactory()).getConditionAndOutcomesBySource() + .values(); + String message = conditionAndOutcomes.iterator().next().iterator().next().getOutcome().getMessage(); + assertThat(message).doesNotContain("@ConditionalOnBean (names: foo; SearchStrategy: all) did not find any beans"); + }); + } @Test void testOnMissingBeanConditionWithFactoryBean() {