mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +00:00
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@34805 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
153 lines
5.0 KiB
Java
153 lines
5.0 KiB
Java
/*
|
|
* Copyright (C) 2005-2012
|
|
Alfresco Software Limited.
|
|
*
|
|
* This file is part of Alfresco
|
|
*
|
|
* Alfresco is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Alfresco is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
package org.alfresco.util.test.junitrules;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Arrays;
|
|
import java.util.List;
|
|
|
|
import org.alfresco.util.ApplicationContextHelper;
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.LogFactory;
|
|
import org.junit.rules.ExternalResource;
|
|
import org.springframework.context.ApplicationContext;
|
|
|
|
/**
|
|
* This JUnit rule can be used to bring up a {@link ApplicationContext spring application context}.
|
|
* <p/>
|
|
* Example usage:
|
|
* <pre>
|
|
* public class YourTestClass
|
|
* {
|
|
* // Parameterless construction brings up the default Alfresco spring configuration.
|
|
* @ClassRule public static final ApplicationContextInit APP_CONTEXT_RULE = new ApplicationContextInit();
|
|
* private static NodeService NODE_SERVICE;
|
|
*
|
|
* @BeforeClass public static void initSpringServices() throws Exception
|
|
* {
|
|
* NODE_SERVICE = (NodeService) APP_CONTEXT_RULE.getApplicationContext().getBean("nodeService");
|
|
* }
|
|
* }
|
|
* </pre>
|
|
*
|
|
* @author Neil Mc Erlean
|
|
* @since Odin
|
|
*/
|
|
public class ApplicationContextInit extends ExternalResource
|
|
{
|
|
/**
|
|
* The locations for the application context configurations.
|
|
*/
|
|
private final String[] configLocations;
|
|
|
|
/**
|
|
* The initialised {@link ApplicationContext spring context}.
|
|
*/
|
|
private ApplicationContext appContext;
|
|
|
|
/**
|
|
* Construct a JUnit rule which will bring up a spring ApplicationContext based on the default Alfresco spring context.
|
|
*/
|
|
public ApplicationContextInit()
|
|
{
|
|
this(new String[0]);
|
|
}
|
|
|
|
/**
|
|
* Construct a JUnit rule which will bring up an ApplicationContext based on the specified spring contexts.
|
|
*
|
|
* @param configLocations locations of spring contexts
|
|
*/
|
|
public ApplicationContextInit(String... configLocations)
|
|
{
|
|
this.configLocations = configLocations;
|
|
}
|
|
|
|
/**
|
|
* This factory method constructs a JUnit rule which will bring up an ApplicationContext consisting
|
|
* of the default Alfresco context with any additionConfigLocations appended. It is a convenient way to specify
|
|
* override contexts in test code.
|
|
*
|
|
* @param additionalConfigLocations addition config locations containing additional or overriding beans.
|
|
*/
|
|
public static ApplicationContextInit createStandardContextWithOverrides(String... additionalConfigLocations)
|
|
{
|
|
List<String> contexts = new ArrayList<String>();
|
|
|
|
// The defaults (currently only one)
|
|
for (String defaultConfigLocation: ApplicationContextHelper.CONFIG_LOCATIONS)
|
|
{
|
|
contexts.add(defaultConfigLocation);
|
|
}
|
|
|
|
// any user supplied extras
|
|
for (String additionalContext : additionalConfigLocations)
|
|
{
|
|
contexts.add(additionalContext);
|
|
}
|
|
|
|
String[] contextsAsArray = contexts.toArray(new String[0]);
|
|
|
|
return new ApplicationContextInit(contextsAsArray);
|
|
}
|
|
|
|
@Override protected void before() throws Throwable
|
|
{
|
|
// Were any context locations specified in the constructor?
|
|
if (configLocations.length > 0)
|
|
{
|
|
log.debug("Initialising custom Spring Configuration: " + Arrays.asList(configLocations).toString());
|
|
|
|
appContext = ApplicationContextHelper.getApplicationContext(configLocations);
|
|
}
|
|
// if not, use the Alfresco default
|
|
else
|
|
{
|
|
log.debug("Initialising default Alfresco Spring Configuration");
|
|
|
|
appContext = ApplicationContextHelper.getApplicationContext();
|
|
}
|
|
}
|
|
|
|
@Override protected void after()
|
|
{
|
|
// Intentionally empty. Do nothing.
|
|
}
|
|
|
|
/**
|
|
* Gets the configLocations as supplied to the code on construction.
|
|
*/
|
|
public List<String> getConfigLocations()
|
|
{
|
|
return Arrays.asList(configLocations);
|
|
}
|
|
|
|
/**
|
|
* Gets the ApplicationContext as initialised by the rule.
|
|
*/
|
|
public ApplicationContext getApplicationContext()
|
|
{
|
|
return this.appContext;
|
|
}
|
|
|
|
private static final Log log = LogFactory.getLog(ApplicationContextInit.class);
|
|
|
|
}
|