mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +00:00
Initial Rule implementations being discussed at tomorrow's Brown Bag. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@34289 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
111 lines
3.4 KiB
Java
111 lines
3.4 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.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}.
|
|
*
|
|
* TODO Sample usage.
|
|
*
|
|
* @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;
|
|
}
|
|
|
|
@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);
|
|
|
|
}
|