Commit c79ecc29 authored by Phillip Webb's avatar Phillip Webb

Polish

parent 7956e682
...@@ -57,12 +57,7 @@ public class ConditionalOnBeanTests { ...@@ -57,12 +57,7 @@ public class ConditionalOnBeanTests {
this.context.register(FooConfiguration.class, this.context.register(FooConfiguration.class,
OnBeanNameAndTypeConfiguration.class); OnBeanNameAndTypeConfiguration.class);
this.context.refresh(); this.context.refresh();
/* assertThat(this.context.containsBean("bar")).isTrue();
* Arguably this should be true, but as things are implemented the conditions
* specified in the different attributes of @ConditionalOnBean are combined with
* logical OR (not AND) so if any of them match the condition is true.
*/
assertThat(this.context.containsBean("bar")).isFalse();
} }
@Test @Test
...@@ -132,28 +127,34 @@ public class ConditionalOnBeanTests { ...@@ -132,28 +127,34 @@ public class ConditionalOnBeanTests {
@Configuration @Configuration
@ConditionalOnBean(name = "foo") @ConditionalOnBean(name = "foo")
protected static class OnBeanNameConfiguration { protected static class OnBeanNameConfiguration {
@Bean @Bean
public String bar() { public String bar() {
return "bar"; return "bar";
} }
} }
@Configuration @Configuration
@ConditionalOnMissingBean(name = "foo", value = Date.class) @ConditionalOnBean(name = "foo", value = Date.class)
protected static class OnBeanNameAndTypeConfiguration { protected static class OnBeanNameAndTypeConfiguration {
@Bean @Bean
public String bar() { public String bar() {
return "bar"; return "bar";
} }
} }
@Configuration @Configuration
@ConditionalOnBean(annotation = EnableScheduling.class) @ConditionalOnBean(annotation = EnableScheduling.class)
protected static class OnAnnotationConfiguration { protected static class OnAnnotationConfiguration {
@Bean @Bean
public String bar() { public String bar() {
return "bar"; return "bar";
} }
} }
@Configuration @Configuration
...@@ -177,30 +178,36 @@ public class ConditionalOnBeanTests { ...@@ -177,30 +178,36 @@ public class ConditionalOnBeanTests {
@Configuration @Configuration
@ConditionalOnBean(type = "some.type.Missing") @ConditionalOnBean(type = "some.type.Missing")
protected static class OnBeanMissingClassConfiguration { protected static class OnBeanMissingClassConfiguration {
@Bean @Bean
public String bar() { public String bar() {
return "bar"; return "bar";
} }
} }
@Configuration @Configuration
@EnableScheduling @EnableScheduling
protected static class FooConfiguration { protected static class FooConfiguration {
@Bean @Bean
public String foo() { public String foo() {
return "foo"; return "foo";
} }
} }
@Configuration @Configuration
@ImportResource("org/springframework/boot/autoconfigure/condition/foo.xml") @ImportResource("org/springframework/boot/autoconfigure/condition/foo.xml")
protected static class XmlConfiguration { protected static class XmlConfiguration {
} }
@Configuration @Configuration
@ImportResource("org/springframework/boot/autoconfigure/condition/foo.xml") @ImportResource("org/springframework/boot/autoconfigure/condition/foo.xml")
@Import(OnBeanNameConfiguration.class) @Import(OnBeanNameConfiguration.class)
protected static class CombinedXmlConfiguration { protected static class CombinedXmlConfiguration {
} }
@Configuration @Configuration
......
...@@ -16,6 +16,8 @@ ...@@ -16,6 +16,8 @@
package org.springframework.boot.autoconfigure.condition; package org.springframework.boot.autoconfigure.condition;
import java.util.Date;
import org.junit.Test; import org.junit.Test;
import org.springframework.beans.factory.FactoryBean; import org.springframework.beans.factory.FactoryBean;
...@@ -66,6 +68,19 @@ public class ConditionalOnMissingBeanTests { ...@@ -66,6 +68,19 @@ public class ConditionalOnMissingBeanTests {
assertThat(this.context.getBean("foo")).isEqualTo("foo"); assertThat(this.context.getBean("foo")).isEqualTo("foo");
} }
@Test
public void testNameAndTypeOnMissingBeanCondition() {
this.context.register(FooConfiguration.class,
OnBeanNameAndTypeConfiguration.class);
this.context.refresh();
/*
* Arguably this should be true, but as things are implemented the conditions
* specified in the different attributes of @ConditionalOnBean are combined with
* logical OR (not AND) so if any of them match the condition is true.
*/
assertThat(this.context.containsBean("bar")).isFalse();
}
@Test @Test
public void hierarchyConsidered() throws Exception { public void hierarchyConsidered() throws Exception {
this.context.register(FooConfiguration.class); this.context.register(FooConfiguration.class);
...@@ -219,49 +234,72 @@ public class ConditionalOnMissingBeanTests { ...@@ -219,49 +234,72 @@ public class ConditionalOnMissingBeanTests {
@Configuration @Configuration
@ConditionalOnMissingBean(name = "foo") @ConditionalOnMissingBean(name = "foo")
protected static class OnBeanNameConfiguration { protected static class OnBeanNameConfiguration {
@Bean @Bean
public String bar() { public String bar() {
return "bar"; return "bar";
} }
}
@Configuration
@ConditionalOnMissingBean(name = "foo", value = Date.class)
@ConditionalOnBean(name = "foo", value = Date.class)
protected static class OnBeanNameAndTypeConfiguration {
@Bean
public String bar() {
return "bar";
}
} }
@Configuration @Configuration
protected static class FactoryBeanConfiguration { protected static class FactoryBeanConfiguration {
@Bean @Bean
public FactoryBean<ExampleBean> exampleBeanFactoryBean() { public FactoryBean<ExampleBean> exampleBeanFactoryBean() {
return new ExampleFactoryBean("foo"); return new ExampleFactoryBean("foo");
} }
} }
@Configuration @Configuration
protected static class FactoryBeanWithBeanMethodArgumentsConfiguration { protected static class FactoryBeanWithBeanMethodArgumentsConfiguration {
@Bean @Bean
public FactoryBean<ExampleBean> exampleBeanFactoryBean( public FactoryBean<ExampleBean> exampleBeanFactoryBean(
@Value("${theValue}") String value) { @Value("${theValue}") String value) {
return new ExampleFactoryBean(value); return new ExampleFactoryBean(value);
} }
} }
@Configuration @Configuration
protected static class ConcreteFactoryBeanConfiguration { protected static class ConcreteFactoryBeanConfiguration {
@Bean @Bean
public ExampleFactoryBean exampleBeanFactoryBean() { public ExampleFactoryBean exampleBeanFactoryBean() {
return new ExampleFactoryBean("foo"); return new ExampleFactoryBean("foo");
} }
} }
@Configuration @Configuration
protected static class UnhelpfulFactoryBeanConfiguration { protected static class UnhelpfulFactoryBeanConfiguration {
@Bean @Bean
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
public FactoryBean exampleBeanFactoryBean() { public FactoryBean exampleBeanFactoryBean() {
return new ExampleFactoryBean("foo"); return new ExampleFactoryBean("foo");
} }
} }
@Configuration @Configuration
@Import(NonspecificFactoryBeanClassAttributeRegistrar.class) @Import(NonspecificFactoryBeanClassAttributeRegistrar.class)
protected static class NonspecificFactoryBeanClassAttributeConfiguration { protected static class NonspecificFactoryBeanClassAttributeConfiguration {
} }
protected static class NonspecificFactoryBeanClassAttributeRegistrar protected static class NonspecificFactoryBeanClassAttributeRegistrar
...@@ -284,6 +322,7 @@ public class ConditionalOnMissingBeanTests { ...@@ -284,6 +322,7 @@ public class ConditionalOnMissingBeanTests {
@Configuration @Configuration
@Import(NonspecificFactoryBeanClassAttributeRegistrar.class) @Import(NonspecificFactoryBeanClassAttributeRegistrar.class)
protected static class NonspecificFactoryBeanStringAttributeConfiguration { protected static class NonspecificFactoryBeanStringAttributeConfiguration {
} }
protected static class NonspecificFactoryBeanStringAttributeRegistrar protected static class NonspecificFactoryBeanStringAttributeRegistrar
...@@ -326,15 +365,18 @@ public class ConditionalOnMissingBeanTests { ...@@ -326,15 +365,18 @@ public class ConditionalOnMissingBeanTests {
@Configuration @Configuration
@ImportResource("org/springframework/boot/autoconfigure/condition/factorybean.xml") @ImportResource("org/springframework/boot/autoconfigure/condition/factorybean.xml")
protected static class FactoryBeanXmlConfiguration { protected static class FactoryBeanXmlConfiguration {
} }
@Configuration @Configuration
protected static class ConditionalOnFactoryBean { protected static class ConditionalOnFactoryBean {
@Bean @Bean
@ConditionalOnMissingBean(ExampleBean.class) @ConditionalOnMissingBean(ExampleBean.class)
public ExampleBean createExampleBean() { public ExampleBean createExampleBean() {
return new ExampleBean("direct"); return new ExampleBean("direct");
} }
} }
@Configuration @Configuration
...@@ -372,45 +414,55 @@ public class ConditionalOnMissingBeanTests { ...@@ -372,45 +414,55 @@ public class ConditionalOnMissingBeanTests {
@Configuration @Configuration
@ConditionalOnMissingBean(annotation = EnableScheduling.class) @ConditionalOnMissingBean(annotation = EnableScheduling.class)
protected static class OnAnnotationConfiguration { protected static class OnAnnotationConfiguration {
@Bean @Bean
public String bar() { public String bar() {
return "bar"; return "bar";
} }
} }
@Configuration @Configuration
@EnableScheduling @EnableScheduling
protected static class FooConfiguration { protected static class FooConfiguration {
@Bean @Bean
public String foo() { public String foo() {
return "foo"; return "foo";
} }
} }
@Configuration @Configuration
@ConditionalOnMissingBean(name = "foo") @ConditionalOnMissingBean(name = "foo")
protected static class HierarchyConsidered { protected static class HierarchyConsidered {
@Bean @Bean
public String bar() { public String bar() {
return "bar"; return "bar";
} }
} }
@Configuration @Configuration
@ConditionalOnMissingBean(name = "foo", search = SearchStrategy.CURRENT) @ConditionalOnMissingBean(name = "foo", search = SearchStrategy.CURRENT)
protected static class HierarchyNotConsidered { protected static class HierarchyNotConsidered {
@Bean @Bean
public String bar() { public String bar() {
return "bar"; return "bar";
} }
} }
@Configuration @Configuration
protected static class ExampleBeanConfiguration { protected static class ExampleBeanConfiguration {
@Bean @Bean
public ExampleBean exampleBean() { public ExampleBean exampleBean() {
return new ExampleBean("test"); return new ExampleBean("test");
} }
} }
@Configuration @Configuration
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment