提交 4cbe2ae0 编写于 作者: S Sam Brannen

[SPR-8387] Introduced supports(MergedContextConfiguration) method in the...

[SPR-8387] Introduced supports(MergedContextConfiguration) method in the SmartContextLoader SPI; updated existing loaders accordingly; and fleshed out implementation of and tests for the new DelegatingSmartContextLoader.
上级 19fc2004
...@@ -95,6 +95,14 @@ public interface SmartContextLoader extends ContextLoader { ...@@ -95,6 +95,14 @@ public interface SmartContextLoader extends ContextLoader {
*/ */
void processContextConfiguration(ContextConfigurationAttributes configAttributes); void processContextConfiguration(ContextConfigurationAttributes configAttributes);
/**
* TODO Document supports(MergedContextConfiguration).
*
* @param mergedConfig
* @return
*/
boolean supports(MergedContextConfiguration mergedConfig);
/** /**
* Loads a new {@link ApplicationContext context} based on the supplied * Loads a new {@link ApplicationContext context} based on the supplied
* {@link MergedContextConfiguration merged context configuration}, * {@link MergedContextConfiguration merged context configuration},
......
...@@ -23,6 +23,7 @@ import org.springframework.core.io.ClassPathResource; ...@@ -23,6 +23,7 @@ import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.support.ResourcePatternUtils; import org.springframework.core.io.support.ResourcePatternUtils;
import org.springframework.test.context.ContextConfigurationAttributes; import org.springframework.test.context.ContextConfigurationAttributes;
import org.springframework.test.context.ContextLoader; import org.springframework.test.context.ContextLoader;
import org.springframework.test.context.MergedContextConfiguration;
import org.springframework.test.context.SmartContextLoader; import org.springframework.test.context.SmartContextLoader;
import org.springframework.util.Assert; import org.springframework.util.Assert;
import org.springframework.util.ClassUtils; import org.springframework.util.ClassUtils;
...@@ -90,6 +91,13 @@ public abstract class AbstractContextLoader implements SmartContextLoader { ...@@ -90,6 +91,13 @@ public abstract class AbstractContextLoader implements SmartContextLoader {
configAttributes.setLocations(processedLocations); configAttributes.setLocations(processedLocations);
} }
/**
* TODO Document default supports(MergedContextConfiguration) implementation.
*/
public boolean supports(MergedContextConfiguration mergedConfig) {
return !ObjectUtils.isEmpty(mergedConfig.getLocations());
}
// --- ContextLoader ------------------------------------------------------- // --- ContextLoader -------------------------------------------------------
/** /**
......
...@@ -81,6 +81,14 @@ public class AnnotationConfigContextLoader extends AbstractGenericContextLoader ...@@ -81,6 +81,14 @@ public class AnnotationConfigContextLoader extends AbstractGenericContextLoader
} }
} }
/**
* TODO Document overridden supports(MergedContextConfiguration) implementation.
*/
@Override
public boolean supports(MergedContextConfiguration mergedConfig) {
return ObjectUtils.isEmpty(mergedConfig.getLocations()) && !ObjectUtils.isEmpty(mergedConfig.getClasses());
}
// --- AnnotationConfigContextLoader --------------------------------------- // --- AnnotationConfigContextLoader ---------------------------------------
private boolean isStaticNonPrivateAndNonFinal(Class<?> clazz) { private boolean isStaticNonPrivateAndNonFinal(Class<?> clazz) {
......
...@@ -26,6 +26,7 @@ import org.springframework.test.context.ContextConfigurationAttributes; ...@@ -26,6 +26,7 @@ import org.springframework.test.context.ContextConfigurationAttributes;
import org.springframework.test.context.ContextLoader; import org.springframework.test.context.ContextLoader;
import org.springframework.test.context.MergedContextConfiguration; import org.springframework.test.context.MergedContextConfiguration;
import org.springframework.test.context.SmartContextLoader; import org.springframework.test.context.SmartContextLoader;
import org.springframework.util.ObjectUtils;
/** /**
* TODO Document DelegatingSmartContextLoader. * TODO Document DelegatingSmartContextLoader.
...@@ -62,6 +63,11 @@ public class DelegatingSmartContextLoader implements SmartContextLoader { ...@@ -62,6 +63,11 @@ public class DelegatingSmartContextLoader implements SmartContextLoader {
* TODO Document processContextConfiguration() implementation. * TODO Document processContextConfiguration() implementation.
*/ */
public void processContextConfiguration(ContextConfigurationAttributes configAttributes) { public void processContextConfiguration(ContextConfigurationAttributes configAttributes) {
final String[] originalLocations = configAttributes.getLocations();
final Class<?>[] originalClasses = configAttributes.getClasses();
final boolean emptyResources = ObjectUtils.isEmpty(originalLocations) && ObjectUtils.isEmpty(originalClasses);
for (SmartContextLoader loader : candidates) { for (SmartContextLoader loader : candidates) {
if (logger.isDebugEnabled()) { if (logger.isDebugEnabled()) {
logger.debug(String.format("Delegating to loader [%s] to process context configuration [%s].", logger.debug(String.format("Delegating to loader [%s] to process context configuration [%s].",
...@@ -73,7 +79,9 @@ public class DelegatingSmartContextLoader implements SmartContextLoader { ...@@ -73,7 +79,9 @@ public class DelegatingSmartContextLoader implements SmartContextLoader {
// If the original locations and classes are not empty, there's no // If the original locations and classes are not empty, there's no
// need to bother with default generation checks; just let each // need to bother with default generation checks; just let each
// loader process the configuration. // loader process the configuration.
// if (!emptyResources) {
loader.processContextConfiguration(configAttributes);
}
// Otherwise, if a loader claims to generate defaults, let it // Otherwise, if a loader claims to generate defaults, let it
// process the configuration, and then verify that it actually did // process the configuration, and then verify that it actually did
// generate defaults. // generate defaults.
...@@ -83,9 +91,26 @@ public class DelegatingSmartContextLoader implements SmartContextLoader { ...@@ -83,9 +91,26 @@ public class DelegatingSmartContextLoader implements SmartContextLoader {
// 1) stop iterating // 1) stop iterating
// 2) mark the current loader as the winning candidate (?) // 2) mark the current loader as the winning candidate (?)
// 3) log an info message. // 3) log an info message.
else {
if (loader.generatesDefaults()) {
loader.processContextConfiguration(configAttributes);
}
}
}
// If any loader claims to generate defaults but none actually did,
// throw an exception.
}
loader.processContextConfiguration(configAttributes); /**
* TODO Document supports(MergedContextConfiguration) implementation.
*/
public boolean supports(MergedContextConfiguration mergedConfig) {
for (SmartContextLoader loader : candidates) {
if (loader.supports(mergedConfig)) {
return true;
}
} }
return false;
} }
/** /**
...@@ -99,21 +124,16 @@ public class DelegatingSmartContextLoader implements SmartContextLoader { ...@@ -99,21 +124,16 @@ public class DelegatingSmartContextLoader implements SmartContextLoader {
loader.getClass().getName(), mergedConfig)); loader.getClass().getName(), mergedConfig));
} }
// TODO Implement loadContext(MergedContextConfiguration). // Ask each loader if it can load a context from the mergedConfig.
//
// Ask each loader if it _can_ load a context from the mergedConfig.
// If a loader can, let it; otherwise, continue iterating over all // If a loader can, let it; otherwise, continue iterating over all
// remaining candidates. // remaining candidates.
// if (loader.supports(mergedConfig)) {
// If no candidate can load a context from the mergedConfig, throw return loader.loadContext(mergedConfig);
// an exception. }
} }
// TODO Implement delegation logic. throw new IllegalStateException(String.format("None of the candidate SmartContextLoaders [%s] "
// + "was able to load an ApplicationContext from [%s].", candidates, mergedConfig));
// Proof of concept: ensuring that hard-coded delegation to
// GenericXmlContextLoader works "as is".
return candidates.get(0).loadContext(mergedConfig);
} }
// --- ContextLoader ------------------------------------------------------- // --- ContextLoader -------------------------------------------------------
......
...@@ -26,6 +26,13 @@ import org.springframework.test.context.junit4.annotation.BeanOverridingDefaultC ...@@ -26,6 +26,13 @@ import org.springframework.test.context.junit4.annotation.BeanOverridingDefaultC
import org.springframework.test.context.junit4.annotation.BeanOverridingExplicitConfigClassesInheritedTests; import org.springframework.test.context.junit4.annotation.BeanOverridingExplicitConfigClassesInheritedTests;
import org.springframework.test.context.junit4.annotation.DefaultConfigClassesBaseTests; import org.springframework.test.context.junit4.annotation.DefaultConfigClassesBaseTests;
import org.springframework.test.context.junit4.annotation.DefaultConfigClassesInheritedTests; import org.springframework.test.context.junit4.annotation.DefaultConfigClassesInheritedTests;
import org.springframework.test.context.junit4.annotation.DefaultLoaderBeanOverridingDefaultConfigClassesInheritedTests;
import org.springframework.test.context.junit4.annotation.DefaultLoaderBeanOverridingExplicitConfigClassesInheritedTests;
import org.springframework.test.context.junit4.annotation.DefaultLoaderDefaultConfigClassesBaseTests;
import org.springframework.test.context.junit4.annotation.DefaultLoaderDefaultConfigClassesInheritedTests;
import org.springframework.test.context.junit4.annotation.DefaultLoaderExplicitConfigClassesBaseTests;
import org.springframework.test.context.junit4.annotation.DefaultLoaderExplicitConfigClassesInheritedTests;
import org.springframework.test.context.junit4.annotation.ExplicitConfigClassesBaseTests;
import org.springframework.test.context.junit4.annotation.ExplicitConfigClassesInheritedTests; import org.springframework.test.context.junit4.annotation.ExplicitConfigClassesInheritedTests;
import org.springframework.test.context.junit4.orm.HibernateSessionFlushingTests; import org.springframework.test.context.junit4.orm.HibernateSessionFlushingTests;
import org.springframework.test.context.junit4.profile.annotation.DefaultProfileAnnotationConfigTests; import org.springframework.test.context.junit4.profile.annotation.DefaultProfileAnnotationConfigTests;
...@@ -58,12 +65,19 @@ StandardJUnit4FeaturesTests.class,// ...@@ -58,12 +65,19 @@ StandardJUnit4FeaturesTests.class,//
DefaultConfigClassesBaseTests.class,// DefaultConfigClassesBaseTests.class,//
DefaultConfigClassesInheritedTests.class,// DefaultConfigClassesInheritedTests.class,//
BeanOverridingDefaultConfigClassesInheritedTests.class,// BeanOverridingDefaultConfigClassesInheritedTests.class,//
ExplicitConfigClassesBaseTests.class,//
ExplicitConfigClassesInheritedTests.class,// ExplicitConfigClassesInheritedTests.class,//
BeanOverridingExplicitConfigClassesInheritedTests.class,// BeanOverridingExplicitConfigClassesInheritedTests.class,//
DefaultLoaderDefaultConfigClassesBaseTests.class,//
DefaultLoaderDefaultConfigClassesInheritedTests.class,//
DefaultLoaderBeanOverridingDefaultConfigClassesInheritedTests.class,//
DefaultLoaderExplicitConfigClassesBaseTests.class,//
DefaultLoaderExplicitConfigClassesInheritedTests.class,//
DefaultLoaderBeanOverridingExplicitConfigClassesInheritedTests.class,//
DefaultProfileAnnotationConfigTests.class,// DefaultProfileAnnotationConfigTests.class,//
DevProfileAnnotationConfigTests.class, // DevProfileAnnotationConfigTests.class,//
DefaultProfileXmlConfigTests.class,// DefaultProfileXmlConfigTests.class,//
DevProfileXmlConfigTests.class, // DevProfileXmlConfigTests.class,//
ExpectedExceptionSpringRunnerTests.class,// ExpectedExceptionSpringRunnerTests.class,//
TimedSpringRunnerTests.class,// TimedSpringRunnerTests.class,//
RepeatedSpringRunnerTests.class,// RepeatedSpringRunnerTests.class,//
......
...@@ -18,7 +18,6 @@ package org.springframework.test.context.junit4.annotation; ...@@ -18,7 +18,6 @@ package org.springframework.test.context.junit4.annotation;
import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunnerAppCtxTests; import org.springframework.test.context.junit4.SpringJUnit4ClassRunnerAppCtxTests;
import org.springframework.test.context.support.AnnotationConfigContextLoader;
/** /**
* Integration tests that verify support for configuration classes in * Integration tests that verify support for configuration classes in
...@@ -34,7 +33,7 @@ import org.springframework.test.context.support.AnnotationConfigContextLoader; ...@@ -34,7 +33,7 @@ import org.springframework.test.context.support.AnnotationConfigContextLoader;
* @author Sam Brannen * @author Sam Brannen
* @since 3.1 * @since 3.1
*/ */
@ContextConfiguration(loader = AnnotationConfigContextLoader.class, classes = PojoAndStringConfig.class, inheritLocations = false) @ContextConfiguration(classes = PojoAndStringConfig.class, inheritLocations = false)
public class AnnotationConfigSpringJUnit4ClassRunnerAppCtxTests extends SpringJUnit4ClassRunnerAppCtxTests { public class AnnotationConfigSpringJUnit4ClassRunnerAppCtxTests extends SpringJUnit4ClassRunnerAppCtxTests {
/* all tests are in the parent class. */ /* all tests are in the parent class. */
} }
...@@ -34,8 +34,15 @@ AnnotationConfigSpringJUnit4ClassRunnerAppCtxTests.class,// ...@@ -34,8 +34,15 @@ AnnotationConfigSpringJUnit4ClassRunnerAppCtxTests.class,//
DefaultConfigClassesBaseTests.class,// DefaultConfigClassesBaseTests.class,//
DefaultConfigClassesInheritedTests.class,// DefaultConfigClassesInheritedTests.class,//
BeanOverridingDefaultConfigClassesInheritedTests.class,// BeanOverridingDefaultConfigClassesInheritedTests.class,//
ExplicitConfigClassesBaseTests.class,//
ExplicitConfigClassesInheritedTests.class,//
BeanOverridingExplicitConfigClassesInheritedTests.class,// BeanOverridingExplicitConfigClassesInheritedTests.class,//
ExplicitConfigClassesInheritedTests.class // DefaultLoaderDefaultConfigClassesBaseTests.class,//
DefaultLoaderDefaultConfigClassesInheritedTests.class,//
DefaultLoaderBeanOverridingDefaultConfigClassesInheritedTests.class,//
DefaultLoaderExplicitConfigClassesBaseTests.class,//
DefaultLoaderExplicitConfigClassesInheritedTests.class,//
DefaultLoaderBeanOverridingExplicitConfigClassesInheritedTests.class //
}) })
public class AnnotationConfigTestSuite { public class AnnotationConfigTestSuite {
} }
...@@ -29,8 +29,8 @@ import org.springframework.test.context.ContextConfiguration; ...@@ -29,8 +29,8 @@ import org.springframework.test.context.ContextConfiguration;
* Integration tests that verify support for configuration classes in * Integration tests that verify support for configuration classes in
* the Spring TestContext Framework. * the Spring TestContext Framework.
* *
* <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTestsConfig} * <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTests.ContextConfiguration}
* and {@link BeanOverridingDefaultConfigClassesInheritedTestsConfig}. * and {@link BeanOverridingDefaultConfigClassesInheritedTests.ContextConfiguration}.
* *
* @author Sam Brannen * @author Sam Brannen
* @since 3.1 * @since 3.1
......
...@@ -26,8 +26,8 @@ import org.springframework.test.context.ContextConfiguration; ...@@ -26,8 +26,8 @@ import org.springframework.test.context.ContextConfiguration;
* Integration tests that verify support for configuration classes in * Integration tests that verify support for configuration classes in
* the Spring TestContext Framework. * the Spring TestContext Framework.
* *
* <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTestsConfig} * <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTests.ContextConfiguration}
* and {@link BeanOverridingDefaultConfigClassesInheritedTestsConfig}. * and {@link BeanOverridingDefaultConfigClassesInheritedTests.ContextConfiguration}.
* *
* @author Sam Brannen * @author Sam Brannen
* @since 3.1 * @since 3.1
......
...@@ -33,7 +33,7 @@ import org.springframework.test.context.support.AnnotationConfigContextLoader; ...@@ -33,7 +33,7 @@ import org.springframework.test.context.support.AnnotationConfigContextLoader;
* Integration tests that verify support for configuration classes in * Integration tests that verify support for configuration classes in
* the Spring TestContext Framework. * the Spring TestContext Framework.
* *
* <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTestsConfig}. * <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTests.ContextConfiguration}.
* *
* @author Sam Brannen * @author Sam Brannen
* @since 3.1 * @since 3.1
......
...@@ -30,8 +30,8 @@ import org.springframework.test.context.ContextConfiguration; ...@@ -30,8 +30,8 @@ import org.springframework.test.context.ContextConfiguration;
* Integration tests that verify support for configuration classes in * Integration tests that verify support for configuration classes in
* the Spring TestContext Framework. * the Spring TestContext Framework.
* *
* <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTestsConfig} * <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTests.ContextConfiguration}
* and {@link DefaultConfigClassesInheritedTestsConfig}. * and {@link DefaultConfigClassesInheritedTests.ContextConfiguration}.
* *
* @author Sam Brannen * @author Sam Brannen
* @since 3.1 * @since 3.1
......
/*
* Copyright 2002-2011 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.test.context.junit4.annotation;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import org.junit.Test;
import org.springframework.beans.Employee;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.support.DelegatingSmartContextLoader;
/**
* Integration tests that verify support for configuration classes in
* the Spring TestContext Framework in conjunction with the
* {@link DelegatingSmartContextLoader}.
*
* @author Sam Brannen
* @since 3.1
*/
@ContextConfiguration
public class DefaultLoaderBeanOverridingDefaultConfigClassesInheritedTests extends
DefaultLoaderDefaultConfigClassesBaseTests {
@Configuration
static class Config {
@Bean
public Employee employee() {
Employee employee = new Employee();
employee.setName("Yoda");
employee.setAge(900);
employee.setCompany("The Force");
return employee;
}
}
@Test
@Override
public void verifyEmployeeSetFromBaseContextConfig() {
assertNotNull("The employee should have been autowired.", this.employee);
assertEquals("The employee bean should have been overridden.", "Yoda", this.employee.getName());
}
}
/*
* Copyright 2002-2011 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.test.context.junit4.annotation;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import org.junit.Test;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.support.DelegatingSmartContextLoader;
/**
* Integration tests that verify support for configuration classes in
* the Spring TestContext Framework in conjunction with the
* {@link DelegatingSmartContextLoader}.
*
* @author Sam Brannen
* @since 3.1
*/
@ContextConfiguration(classes = DefaultLoaderBeanOverridingDefaultConfigClassesInheritedTests.Config.class)
public class DefaultLoaderBeanOverridingExplicitConfigClassesInheritedTests extends
DefaultLoaderExplicitConfigClassesBaseTests {
@Test
@Override
public void verifyEmployeeSetFromBaseContextConfig() {
assertNotNull("The employee should have been autowired.", this.employee);
assertEquals("The employee bean should have been overridden.", "Yoda", this.employee.getName());
}
}
/*
* Copyright 2002-2011 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.test.context.junit4.annotation;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.Employee;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.support.DelegatingSmartContextLoader;
/**
* Integration tests that verify support for configuration classes in
* the Spring TestContext Framework in conjunction with the
* {@link DelegatingSmartContextLoader}.
*
* @author Sam Brannen
* @since 3.1
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration
public class DefaultLoaderDefaultConfigClassesBaseTests {
@Configuration
static class Config {
@Bean
public Employee employee() {
Employee employee = new Employee();
employee.setName("John Smith");
employee.setAge(42);
employee.setCompany("Acme Widgets, Inc.");
return employee;
}
}
@Autowired
protected Employee employee;
@Test
public void verifyEmployeeSetFromBaseContextConfig() {
assertNotNull("The employee field should have been autowired.", this.employee);
assertEquals("John Smith", this.employee.getName());
}
}
/*
* Copyright 2002-2011 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.test.context.junit4.annotation;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import org.junit.Test;
import org.springframework.beans.Pet;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.support.DelegatingSmartContextLoader;
/**
* Integration tests that verify support for configuration classes in
* the Spring TestContext Framework in conjunction with the
* {@link DelegatingSmartContextLoader}.
*
* @author Sam Brannen
* @since 3.1
*/
@ContextConfiguration
public class DefaultLoaderDefaultConfigClassesInheritedTests extends DefaultLoaderDefaultConfigClassesBaseTests {
@Configuration
static class Config {
@Bean
public Pet pet() {
return new Pet("Fido");
}
}
@Autowired
private Pet pet;
@Test
public void verifyPetSetFromExtendedContextConfig() {
assertNotNull("The pet should have been autowired.", this.pet);
assertEquals("Fido", this.pet.getName());
}
}
/*
* Copyright 2002-2011 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.test.context.junit4.annotation;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.Employee;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.support.DelegatingSmartContextLoader;
/**
* Integration tests that verify support for configuration classes in
* the Spring TestContext Framework in conjunction with the
* {@link DelegatingSmartContextLoader}.
*
* @author Sam Brannen
* @since 3.1
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = DefaultLoaderDefaultConfigClassesBaseTests.Config.class)
public class DefaultLoaderExplicitConfigClassesBaseTests {
@Autowired
protected Employee employee;
@Test
public void verifyEmployeeSetFromBaseContextConfig() {
assertNotNull("The employee should have been autowired.", this.employee);
assertEquals("John Smith", this.employee.getName());
}
}
/*
* Copyright 2002-2011 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.test.context.junit4.annotation;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.Pet;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.support.DelegatingSmartContextLoader;
/**
* Integration tests that verify support for configuration classes in
* the Spring TestContext Framework in conjunction with the
* {@link DelegatingSmartContextLoader}.
*
* @author Sam Brannen
* @since 3.1
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = DefaultLoaderDefaultConfigClassesInheritedTests.Config.class)
public class DefaultLoaderExplicitConfigClassesInheritedTests extends DefaultLoaderExplicitConfigClassesBaseTests {
@Autowired
private Pet pet;
@Test
public void verifyPetSetFromExtendedContextConfig() {
assertNotNull("The pet should have been autowired.", this.pet);
assertEquals("Fido", this.pet.getName());
}
}
...@@ -31,7 +31,7 @@ import org.springframework.test.context.support.AnnotationConfigContextLoader; ...@@ -31,7 +31,7 @@ import org.springframework.test.context.support.AnnotationConfigContextLoader;
* Integration tests that verify support for configuration classes in * Integration tests that verify support for configuration classes in
* the Spring TestContext Framework. * the Spring TestContext Framework.
* *
* <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTestsConfig}. * <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTests.ContextConfiguration}.
* *
* @author Sam Brannen * @author Sam Brannen
* @since 3.1 * @since 3.1
......
...@@ -31,8 +31,8 @@ import org.springframework.test.context.support.AnnotationConfigContextLoader; ...@@ -31,8 +31,8 @@ import org.springframework.test.context.support.AnnotationConfigContextLoader;
* Integration tests that verify support for configuration classes in * Integration tests that verify support for configuration classes in
* the Spring TestContext Framework. * the Spring TestContext Framework.
* *
* <p>Configuration will be loaded from {@link DefaultConfigClassesBaseTestsConfig} * <p>Configuration will be loaded from {@link DefaultConfigClassesInheritedTests.ContextConfiguration}
* and {@link DefaultConfigClassesInheritedTestsConfig} * and {@link DefaultConfigClassesBaseTests.ContextConfiguration}.
* *
* @author Sam Brannen * @author Sam Brannen
* @since 3.1 * @since 3.1
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册