package org.argeo.slc.unit; import junit.framework.TestCase; import org.springframework.context.ApplicationContext; import org.springframework.context.ConfigurableApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.argeo.slc.core.SlcException; import org.argeo.slc.spring.SpringUtils; /** Helper for tests using a Spring application co,text. */ public abstract class AbstractSpringTestCase extends TestCase { protected final Log log = LogFactory.getLog(getClass()); private ConfigurableApplicationContext context; /** * Gets (and create if necessary) the application context to use. Default * implementation uses a class path xml application context and calls * {@link #getApplicationContextLocation()}. */ protected ConfigurableApplicationContext getContext() { if (context == null) { context = new ClassPathXmlApplicationContext( getApplicationContextLocation()); } return context; } /** Returns a bean from the underlying context */ protected T getBean(String beanId) { return (T) getContext().getBean(beanId); } protected T getBean(Class clss) { T bean = SpringUtils.loadSingleFromContext(getContext(), clss); if (bean == null) { throw new SlcException("Cannot retrieve a unique bean of type " + clss); } else { return bean; } } /** * Th location of the application to load. The default implementation * returns applicationContext.xml found in the same package as the * test. */ protected String getApplicationContextLocation() { return inPackage("applicationContext.xml"); } /** * Prefixes the package of the class after converting the '.' to '/' in * order to have a resource path. */ protected String inPackage(String suffix) { String prefix = getClass().getPackage().getName().replace('.', '/'); return prefix + '/' + suffix; } }