From 8cb5c36512e6355d379f533d75d2bef63d0de6bd Mon Sep 17 00:00:00 2001 From: Chris Beams Date: Fri, 17 Jun 2011 09:46:19 +0000 Subject: [PATCH] Consolidate tests related to @Config inheritance Issue: SPR-8183 --- .../BeanMethodPolymorphismTests.java | 35 ++++++++++- .../PolymorphicConfigurationTests.java | 63 ------------------- 2 files changed, 34 insertions(+), 64 deletions(-) delete mode 100644 org.springframework.context/src/test/java/org/springframework/context/annotation/configuration/PolymorphicConfigurationTests.java diff --git a/org.springframework.context/src/test/java/org/springframework/context/annotation/BeanMethodPolymorphismTests.java b/org.springframework.context/src/test/java/org/springframework/context/annotation/BeanMethodPolymorphismTests.java index be7e4e9ae4a..4797aae61be 100644 --- a/org.springframework.context/src/test/java/org/springframework/context/annotation/BeanMethodPolymorphismTests.java +++ b/org.springframework.context/src/test/java/org/springframework/context/annotation/BeanMethodPolymorphismTests.java @@ -5,8 +5,12 @@ import static org.junit.Assert.assertThat; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; +import java.lang.annotation.Inherited; + import org.junit.Test; import org.springframework.beans.factory.parsing.BeanDefinitionParsingException; +import org.springframework.beans.factory.support.DefaultListableBeanFactory; +import org.springframework.beans.factory.support.RootBeanDefinition; /** * Tests regarding overloading and overriding of bean methods. @@ -52,7 +56,7 @@ public class BeanMethodPolymorphismTests { @Bean Integer anInt() { return 5; } @Bean String aString(Integer dependency) { return "overloaded"+dependency; } } - + /** * When inheritance is not involved, it is still possible to override a bean method from * the container's point of view. This is not strictly 'overloading' of a method per se, @@ -68,4 +72,33 @@ public class BeanMethodPolymorphismTests { @Bean String aString() { return "shadow"; } } + /** + * Tests that polymorphic Configuration classes need not explicitly redeclare the + * {@link Configuration} annotation. This respects the {@link Inherited} nature + * of the Configuration annotation, even though it's being detected via ASM. + */ + @Test + public void beanMethodsDetectedOnSuperClass() { + DefaultListableBeanFactory beanFactory = new DefaultListableBeanFactory(); + beanFactory.registerBeanDefinition("config", new RootBeanDefinition(Config.class)); + ConfigurationClassPostProcessor pp = new ConfigurationClassPostProcessor(); + pp.postProcessBeanFactory(beanFactory); + beanFactory.getBean("testBean", TestBean.class); + } + + + @Configuration + static class BaseConfig { + + @Bean + public TestBean testBean() { + return new TestBean(); + } + } + + + @Configuration + static class Config extends BaseConfig { + } + } diff --git a/org.springframework.context/src/test/java/org/springframework/context/annotation/configuration/PolymorphicConfigurationTests.java b/org.springframework.context/src/test/java/org/springframework/context/annotation/configuration/PolymorphicConfigurationTests.java deleted file mode 100644 index 52532a28e58..00000000000 --- a/org.springframework.context/src/test/java/org/springframework/context/annotation/configuration/PolymorphicConfigurationTests.java +++ /dev/null @@ -1,63 +0,0 @@ -/* - * Copyright 2002-2009 the original author or authors. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package org.springframework.context.annotation.configuration; - -import java.lang.annotation.Inherited; - -import org.junit.Test; -import test.beans.TestBean; - -import org.springframework.beans.factory.support.DefaultListableBeanFactory; -import org.springframework.beans.factory.support.RootBeanDefinition; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; -import org.springframework.context.annotation.ConfigurationClassPostProcessor; - -/** - * Tests that polymorphic Configuration classes need not explicitly redeclare the - * {@link Configuration} annotation. This respects the {@link Inherited} nature - * of the Configuration annotation, even though it's being detected via ASM. - * - * @author Chris Beams - */ -public class PolymorphicConfigurationTests { - - @Test - public void beanMethodsDetectedOnSuperClass() { - DefaultListableBeanFactory beanFactory = new DefaultListableBeanFactory(); - beanFactory.registerBeanDefinition("config", new RootBeanDefinition(Config.class)); - ConfigurationClassPostProcessor pp = new ConfigurationClassPostProcessor(); - pp.postProcessBeanFactory(beanFactory); - beanFactory.getBean("testBean", TestBean.class); - } - - - @Configuration - static class SuperConfig { - - @Bean - public TestBean testBean() { - return new TestBean(); - } - } - - - @Configuration - static class Config extends SuperConfig { - } - -}