mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-31 17:39:05 +00:00
Merged V4.0-BUG-FIX to HEAD
37207: BDE-69: Filter more tests for minimal build plan 37253: Fix for ALF-13634 Re-created category won't show up again on a node in Document Library. - also fixes deletion of secondary associations 37265: Merged V4.0 to V4.0-BUG-FIX 37224: ALF-14174: Part 14 for ALF-14237 Upgrades from 4.0.0.x/4..0.1.0 will not fix the timestamps on acl changesets - SOLR will skip ACLs set prior to upgrade - Fix syntax error on Oracle 37250: Fix for ALF-14174 The patch adding timestamps to acl_change_set breaks SOLR tracking - better cross DB fix 37298: ALF-14365 - added hazelcastConfig.xml.sample 37323: ALF-13247: Two nodes with the same primary path. -Fixed by initializing zone before parallel batch processing begins. 37326: ALF-13933 Alfresco needs to be able to support LibreOffice for transformations ALF-13452 Open office startup from Java not working on OSX - Added code to start LibreOffice 3.5 on Mac (requires different options to the command and ure-link is a directory rather than a file on mac) - Removes $DYLD_LIBRARY_PATH from the environment when starting either openoffice or libreoffice on mac so does not need to rely on the installer moving the soffice.bin process to .soffice.bin and then creating a soffice.bin shell script that removed $DYLD_LIBRARY_PATH - Indent TransformerDebug a bit more now we have fail over transformers at the top and lower levels (saves N.N.N.N.N.N getting mixed up with text) 37340: Merged V3.4-BUG-FIX (3.4.10) to V4.0-BUG-FIX (4.0.3) RECORD ONLY 37339: ALF-13452: Merged V4.0-BUG-FIX (4.0.3) to V3.4-BUG-FIX (3.4.10) 37326: ALF-13933 Alfresco needs to be able to support LibreOffice for transformations ALF-13452 Open office startup from Java not working on OSX - Added code to start LibreOffice 3.5 on Mac (requires different options to the command and ure-link is a directory rather than a file on mac) - Removes $DYLD_LIBRARY_PATH from the environment when starting either openoffice or libreoffice on mac so does not need to rely on the installer moving the soffice.bin process to .soffice.bin and then creating a soffice.bin shell script that removed $DYLD_LIBRARY_PATH - Indent TransformerDebug a bit more now we have fail over transformers at the top and lower levels (saves N.N.N.N.N.N getting mixed up with text) 36273: ALF-13933 Alfresco needs to be able to support LibreOffice for transformations - Return a dummy OpenOffice command even when there is no OpenOffice/LibreOffice installed or on the path. 36264: ALF-13933 Alfresco needs to be able to support LibreOffice for transformations - remove old jodconverter-core-3.0-beta-3.diff 36259: ALF-13933 Alfresco needs to be able to support LibreOffice for transformations << Developed on Windows 7. Might need more work on Linux to get LibreOffice to shut down, but should be okay with OpenOffice 3.2 which was used in the previous release. >> - Updated jodconverter to latest version jodconverter-core-3.0-SNAPSHOT-patched.jar 28/4/2012 which is newer than 3.0 beta-4 - Applied patch for http://code.google.com/p/jodconverter/issues/detail?id=103 to handle setting the env for LibreOffice 3.5 - Modified code to use partial GNU style options (not used for -env!) when using LibreOffice - Added OpenOfficeCommandLine to dynamically supply OpenOffice or LibreOffice command line args for OOoDirect - Tested to work with OpenOffice 3.4 and 3.2 on Windows 7 37353: Merged V3.4-BUG-FIX (3.4.10) to V4.0-BUG-FIX (4.0.3) 37352: ALF-13452, ALF-13933 Alfresco needs to be able to support LibreOffice for transformations - Build test failure 37359: New JUnit Rule to support automatic creation and cleanup of Share sites in test code. This is required for an imminent fix to ALF-14345, but I'm checking it in separately in order to merge this general utility. 37360: Fix for ALF-14345. Site Service list method does not recognise sub-types of st:site. 37364: Merged V3.4-BUG-FIX (3.4.10) to V4.0-BUG-FIX (4.0.3) RECORD ONLY (not needed in 4.0.x) 37363: ALF-13452, ALF-13933 Alfresco needs to be able to support LibreOffice for transformations - Build test failure x2 (reference to jodconverter*jar not needed in 4.0.x) 37370: Merged V3.4-BUG-FIX: ALF-11714: Updated WCMQS to ensure all FreeMarker variables output to HTML are protected with ?html to prevent XSS 37382: Translation (DE, IT, JA, NL) updates from Gloria, based on EN rev37081 37384: Fix for ALF-14219 SolrQueryHTTPClient unable to handle long queries (4096 bytes) 37386: Merged V4.0 to V4.0-BUG-FIX 37385: ALF-14238: Fix by Dmitry to correct iteration in ImapUnsubscribedAspectPatch git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@37387 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
62
source/java/org/alfresco/util/OpenOfficeCommandEnv.java
Normal file
62
source/java/org/alfresco/util/OpenOfficeCommandEnv.java
Normal file
@@ -0,0 +1,62 @@
|
||||
/* 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;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.util.AbstractMap;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
import org.alfresco.error.AlfrescoRuntimeException;
|
||||
import org.alfresco.util.OpenOfficeURI;
|
||||
import org.alfresco.util.exec.RuntimeExec;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
|
||||
/**
|
||||
* A map giving the environment openoffice or libreoffice commands require to start.
|
||||
*
|
||||
* @author Alan Davis
|
||||
*/
|
||||
public class OpenOfficeCommandEnv extends AbstractMap<String, String>
|
||||
{
|
||||
private static final Log logger = LogFactory.getLog(OpenOfficeCommandLine.class);
|
||||
private static final String DYLD_LIBRARY_PATH = "DYLD_LIBRARY_PATH";
|
||||
|
||||
private Map<String, String> map = new HashMap<String, String>(System.getenv());
|
||||
private OpenOfficeVariant variant = new OpenOfficeVariant();
|
||||
|
||||
public OpenOfficeCommandEnv(String exe) throws IOException
|
||||
{
|
||||
if (variant.isMac())
|
||||
{
|
||||
map.remove(DYLD_LIBRARY_PATH);
|
||||
logger.debug("Removing $DYLD_LIBRARY_PATH from the environment so that LibreOffice/OpenOffice will start on Mac.");
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public Set<java.util.Map.Entry<String, String>> entrySet()
|
||||
{
|
||||
return map.entrySet();
|
||||
}
|
||||
}
|
@@ -26,7 +26,6 @@ import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
import org.alfresco.error.AlfrescoRuntimeException;
|
||||
import org.alfresco.util.OpenOfficeURI;
|
||||
import org.alfresco.util.exec.RuntimeExec;
|
||||
import org.apache.commons.logging.Log;
|
||||
@@ -40,30 +39,30 @@ import org.apache.commons.logging.LogFactory;
|
||||
*/
|
||||
public class OpenOfficeCommandLine extends AbstractMap<String, List<String>>
|
||||
{
|
||||
private static final String[] EXTENSIONS = new String[] {"", ".exe", ".com", ".bat", ".cmd"};
|
||||
|
||||
private static final Log logger = LogFactory.getLog(OpenOfficeCommandLine.class);
|
||||
|
||||
private static final String OS_NAME = System.getProperty("os.name").toLowerCase();
|
||||
|
||||
private Map<String, List<String>> map = new HashMap<String, List<String>>();
|
||||
|
||||
private boolean windows;
|
||||
private OpenOfficeVariant variant = new OpenOfficeVariant();
|
||||
|
||||
public OpenOfficeCommandLine(String exe, String port, String user) throws IOException
|
||||
{
|
||||
windows = isWindows();
|
||||
File executable = findExecutable(exe);
|
||||
File officeHome = getOfficeHome(executable);
|
||||
File executable = variant.findExecutable(exe);
|
||||
File officeHome = variant.getOfficeHome(executable);
|
||||
|
||||
List<String> command = new ArrayList<String>();
|
||||
String acceptValue = "socket,host=127.0.0.1,port="+port+";urp;StarOffice.ServiceManager";
|
||||
String userInstallation = new OpenOfficeURI(user).toString();
|
||||
command.add(executable == null ? exe : executable.getAbsolutePath());
|
||||
if (isLibreOffice3Dot5(officeHome))
|
||||
if (variant.isLibreOffice3Dot5(officeHome))
|
||||
{
|
||||
command.add("--accept=" + acceptValue);
|
||||
command.add("-env:UserInstallation=" + userInstallation);
|
||||
if (variant.isMac())
|
||||
{
|
||||
command.add("--env:UserInstallation=" + userInstallation);
|
||||
}
|
||||
else
|
||||
{
|
||||
command.add("-env:UserInstallation=" + userInstallation);
|
||||
}
|
||||
command.add("--headless");
|
||||
command.add("--nocrashreport");
|
||||
//command.add("--nodefault"); included by JOD
|
||||
@@ -71,7 +70,7 @@ public class OpenOfficeCommandLine extends AbstractMap<String, List<String>>
|
||||
//command.add("--nolockcheck"); included by JOD
|
||||
command.add("--nologo");
|
||||
command.add("--norestore");
|
||||
logger.info("Using GNU based LibreOffice command: "+command);
|
||||
logger.info("Using GNU based LibreOffice command"+(variant.isMac() ? " on Mac" : "")+": "+command);
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -89,100 +88,6 @@ public class OpenOfficeCommandLine extends AbstractMap<String, List<String>>
|
||||
map.put(RuntimeExec.KEY_OS_DEFAULT, command);
|
||||
}
|
||||
|
||||
private File getOfficeHome(File executable)
|
||||
{
|
||||
// Get the grandparent
|
||||
File officeHome = executable;
|
||||
for (int i=1; officeHome != null && i <= 2; i++)
|
||||
{
|
||||
officeHome = officeHome.getParentFile();
|
||||
}
|
||||
|
||||
if (officeHome == null && executable != null)
|
||||
{
|
||||
throw new AlfrescoRuntimeException("Did not find OppenOffice home from executable "+executable.getAbsolutePath());
|
||||
}
|
||||
|
||||
return officeHome;
|
||||
}
|
||||
|
||||
private File findExecutable(String executableName)
|
||||
{
|
||||
File file = new File(executableName);
|
||||
if (file.isAbsolute())
|
||||
{
|
||||
file = canExecute(file);
|
||||
}
|
||||
else
|
||||
{
|
||||
file = findExecutableOnPath(executableName);
|
||||
}
|
||||
return file;
|
||||
}
|
||||
|
||||
private File findExecutableOnPath(String executableName)
|
||||
{
|
||||
String systemPath = System.getenv("PATH");
|
||||
systemPath = systemPath == null ? System.getenv("path") : systemPath;
|
||||
String[] pathDirs = systemPath.split(File.pathSeparator);
|
||||
|
||||
File fullyQualifiedExecutable = null;
|
||||
for (String pathDir : pathDirs)
|
||||
{
|
||||
File file = canExecute(new File(pathDir, executableName));
|
||||
if (file != null)
|
||||
{
|
||||
fullyQualifiedExecutable = file;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return fullyQualifiedExecutable;
|
||||
}
|
||||
|
||||
private File canExecute(File file)
|
||||
{
|
||||
File fullyQualifiedExecutable = null;
|
||||
File dir = file.getParentFile();
|
||||
String name = file.getName();
|
||||
for (String ext: EXTENSIONS)
|
||||
{
|
||||
file = new File(dir, name+ext);
|
||||
if (file.canExecute())
|
||||
{
|
||||
fullyQualifiedExecutable = file;
|
||||
break;
|
||||
}
|
||||
if (!windows)
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
return fullyQualifiedExecutable;
|
||||
}
|
||||
|
||||
private boolean isLibreOffice3Dot5(File officeHome)
|
||||
{
|
||||
return
|
||||
officeHome != null &&
|
||||
!new File(officeHome, "basis-link").isFile() &&
|
||||
new File(officeHome, "ure-link").isFile();
|
||||
}
|
||||
|
||||
private static boolean isLinux()
|
||||
{
|
||||
return OS_NAME.startsWith("linux");
|
||||
}
|
||||
|
||||
private static boolean isMac()
|
||||
{
|
||||
return OS_NAME.startsWith("mac");
|
||||
}
|
||||
|
||||
private static boolean isWindows()
|
||||
{
|
||||
return OS_NAME.startsWith("windows");
|
||||
}
|
||||
|
||||
@Override
|
||||
public Set<java.util.Map.Entry<String, List<String>>> entrySet()
|
||||
{
|
||||
|
139
source/java/org/alfresco/util/OpenOfficeVariant.java
Normal file
139
source/java/org/alfresco/util/OpenOfficeVariant.java
Normal file
@@ -0,0 +1,139 @@
|
||||
/* 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;
|
||||
|
||||
import java.io.File;
|
||||
|
||||
import org.alfresco.error.AlfrescoRuntimeException;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
|
||||
/**
|
||||
* Provides OpenOffice and LibreOffice variant information.
|
||||
*
|
||||
* @author Alan Davis
|
||||
*/
|
||||
public class OpenOfficeVariant
|
||||
{
|
||||
private static final String[] EXTENSIONS = new String[] {"", ".exe", ".com", ".bat", ".cmd"};
|
||||
private static final Log logger = LogFactory.getLog(OpenOfficeCommandLine.class);
|
||||
private static final String OS_NAME = System.getProperty("os.name").toLowerCase();
|
||||
|
||||
private final boolean windows = isWindows();
|
||||
|
||||
public File getOfficeHome(File executable)
|
||||
{
|
||||
// Get the grandparent
|
||||
File officeHome = executable;
|
||||
for (int i=1; officeHome != null && i <= 2; i++)
|
||||
{
|
||||
officeHome = officeHome.getParentFile();
|
||||
}
|
||||
|
||||
if (officeHome == null && executable != null)
|
||||
{
|
||||
throw new AlfrescoRuntimeException("Did not find OppenOffice home from executable "+executable.getAbsolutePath());
|
||||
}
|
||||
|
||||
return officeHome;
|
||||
}
|
||||
|
||||
public File findExecutable(String executableName)
|
||||
{
|
||||
File file = new File(executableName);
|
||||
if (file.isAbsolute())
|
||||
{
|
||||
file = canExecute(file);
|
||||
}
|
||||
else
|
||||
{
|
||||
file = findExecutableOnPath(executableName);
|
||||
}
|
||||
return file;
|
||||
}
|
||||
|
||||
private File findExecutableOnPath(String executableName)
|
||||
{
|
||||
String systemPath = System.getenv("PATH");
|
||||
systemPath = systemPath == null ? System.getenv("path") : systemPath;
|
||||
String[] pathDirs = systemPath.split(File.pathSeparator);
|
||||
|
||||
File fullyQualifiedExecutable = null;
|
||||
for (String pathDir : pathDirs)
|
||||
{
|
||||
File file = canExecute(new File(pathDir, executableName));
|
||||
if (file != null)
|
||||
{
|
||||
fullyQualifiedExecutable = file;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return fullyQualifiedExecutable;
|
||||
}
|
||||
|
||||
private File canExecute(File file)
|
||||
{
|
||||
File fullyQualifiedExecutable = null;
|
||||
File dir = file.getParentFile();
|
||||
String name = file.getName();
|
||||
for (String ext: EXTENSIONS)
|
||||
{
|
||||
file = new File(dir, name+ext);
|
||||
if (file.canExecute())
|
||||
{
|
||||
fullyQualifiedExecutable = file;
|
||||
break;
|
||||
}
|
||||
if (!windows)
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
return fullyQualifiedExecutable;
|
||||
}
|
||||
|
||||
public boolean isLibreOffice3Dot5(File officeHome)
|
||||
{
|
||||
logger.debug("System.getProperty(\"os.name\")="+System.getProperty("os.name"));
|
||||
logger.debug("officeHome="+(officeHome == null ? null : "'"+officeHome.getAbsolutePath()+"'"));
|
||||
logger.debug("basis-link:"+new File(officeHome, "basis-link").isFile());
|
||||
logger.debug(" ure-link:"+new File(officeHome, "ure-link").isFile());
|
||||
logger.debug("basis-link:"+new File(officeHome, "basis-link").isDirectory());
|
||||
logger.debug(" ure-link:"+new File(officeHome, "ure-link").isDirectory());
|
||||
|
||||
return
|
||||
officeHome != null &&
|
||||
!new File(officeHome, "basis-link").isFile() &&
|
||||
(new File(officeHome, "ure-link").isFile() || new File(officeHome, "ure-link").isDirectory());
|
||||
}
|
||||
|
||||
public boolean isLinux()
|
||||
{
|
||||
return OS_NAME.startsWith("linux");
|
||||
}
|
||||
|
||||
public boolean isMac()
|
||||
{
|
||||
return OS_NAME.startsWith("mac");
|
||||
}
|
||||
|
||||
public boolean isWindows()
|
||||
{
|
||||
return OS_NAME.startsWith("windows");
|
||||
}
|
||||
}
|
@@ -0,0 +1,165 @@
|
||||
/*
|
||||
* 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.List;
|
||||
|
||||
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||
import org.alfresco.repo.security.authentication.AuthenticationUtil.RunAsWork;
|
||||
import org.alfresco.repo.site.SiteModel;
|
||||
import org.alfresco.repo.transaction.RetryingTransactionHelper;
|
||||
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
||||
import org.alfresco.service.cmr.site.SiteInfo;
|
||||
import org.alfresco.service.cmr.site.SiteService;
|
||||
import org.alfresco.service.cmr.site.SiteVisibility;
|
||||
import org.alfresco.service.namespace.QName;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
import org.junit.rules.ExternalResource;
|
||||
|
||||
/**
|
||||
* A JUnit rule designed to help with the automatic cleanup of temporary st:site nodes.
|
||||
*
|
||||
* @author Neil Mc Erlean
|
||||
* @since 4.0.3
|
||||
*/
|
||||
public class TemporarySites extends ExternalResource
|
||||
{
|
||||
private static final Log log = LogFactory.getLog(TemporarySites.class);
|
||||
|
||||
private final ApplicationContextInit appContextRule;
|
||||
private List<SiteInfo> temporarySites = new ArrayList<SiteInfo>();
|
||||
|
||||
/**
|
||||
* Constructs the rule with a reference to a {@link ApplicationContextInit rule} which can be used to retrieve the ApplicationContext.
|
||||
*
|
||||
* @param appContextRule a rule which can be used to retrieve the spring app context.
|
||||
*/
|
||||
public TemporarySites(ApplicationContextInit appContextRule)
|
||||
{
|
||||
this.appContextRule = appContextRule;
|
||||
}
|
||||
|
||||
|
||||
@Override protected void before() throws Throwable
|
||||
{
|
||||
// Intentionally empty
|
||||
}
|
||||
|
||||
@Override protected void after()
|
||||
{
|
||||
final RetryingTransactionHelper transactionHelper = (RetryingTransactionHelper) appContextRule.getApplicationContext().getBean("retryingTransactionHelper");
|
||||
final SiteService siteService = appContextRule.getApplicationContext().getBean("siteService", SiteService.class);
|
||||
|
||||
// Run as admin to ensure all sites can be deleted irrespective of which user created them.
|
||||
AuthenticationUtil.runAs(new RunAsWork<Void>()
|
||||
{
|
||||
@Override public Void doWork() throws Exception
|
||||
{
|
||||
transactionHelper.doInTransaction(new RetryingTransactionCallback<Void>()
|
||||
{
|
||||
@Override public Void execute() throws Throwable
|
||||
{
|
||||
for (SiteInfo site : temporarySites)
|
||||
{
|
||||
final String shortName = site.getShortName();
|
||||
if (siteService.getSite(shortName) != null)
|
||||
{
|
||||
log.debug("Deleting temporary site " + shortName);
|
||||
siteService.deleteSite(shortName);
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
});
|
||||
return null;
|
||||
}
|
||||
}, AuthenticationUtil.getAdminUserName());
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a specified site to the list of SiteInfos to be deleted by this rule.
|
||||
*
|
||||
* @param temporarySite a SiteInfo
|
||||
*/
|
||||
public void addSite(SiteInfo temporarySite)
|
||||
{
|
||||
this.temporarySites.add(temporarySite);
|
||||
}
|
||||
|
||||
/**
|
||||
* This method creates a Share Site and adds it to the internal list of NodeRefs to be tidied up by the rule.
|
||||
* This method will be run in its own transaction and will be run with the specified user as the fully authenticated user,
|
||||
* thus ensuring the named user is the creator of the new site.
|
||||
*
|
||||
* @param sitePreset the site preset
|
||||
* @param siteShortName the short name of the new site
|
||||
* @param siteTitle the title of the new site
|
||||
* @param siteDescription the description of the new site
|
||||
* @param visibility the visibility
|
||||
* @param siteCreator the username of the person who will create the site
|
||||
* @return the newly created SiteInfo (will be of type st:site).
|
||||
*/
|
||||
public SiteInfo createSite(final String sitePreset, final String siteShortName, final String siteTitle, final String siteDescription,
|
||||
final SiteVisibility visibility, final String siteCreator)
|
||||
{
|
||||
return this.createSite(sitePreset, siteShortName, siteTitle, siteDescription, visibility, SiteModel.TYPE_SITE, siteCreator);
|
||||
}
|
||||
|
||||
/**
|
||||
* This method creates a Share Site (<b>or subtype</b>) and adds it to the internal list of NodeRefs to be tidied up by the rule.
|
||||
* This method will be run in its own transaction and will be run with the specified user as the fully authenticated user,
|
||||
* thus ensuring the named user is the creator of the new site.
|
||||
*
|
||||
* @param sitePreset the site preset
|
||||
* @param siteShortName the short name of the new site
|
||||
* @param siteTitle the title of the new site
|
||||
* @param siteDescription the description of the new site
|
||||
* @param visibility the visibility
|
||||
* @param node type the node type of the site (must be st:site or subtype)
|
||||
* @param siteCreator the username of the person who will create the site
|
||||
* @return the newly created SiteInfo.
|
||||
*/
|
||||
public SiteInfo createSite(final String sitePreset, final String siteShortName, final String siteTitle, final String siteDescription,
|
||||
final SiteVisibility visibility, final QName siteType, final String siteCreator)
|
||||
{
|
||||
final RetryingTransactionHelper transactionHelper = appContextRule.getApplicationContext().getBean("retryingTransactionHelper", RetryingTransactionHelper.class);
|
||||
|
||||
AuthenticationUtil.pushAuthentication();
|
||||
AuthenticationUtil.setFullyAuthenticatedUser(siteCreator);
|
||||
|
||||
SiteInfo newSite = transactionHelper.doInTransaction(new RetryingTransactionCallback<SiteInfo>()
|
||||
{
|
||||
public SiteInfo execute() throws Throwable
|
||||
{
|
||||
final SiteService siteService = appContextRule.getApplicationContext().getBean("siteService", SiteService.class);
|
||||
|
||||
return siteService.createSite(sitePreset, siteShortName, siteTitle, siteDescription, visibility, siteType);
|
||||
}
|
||||
});
|
||||
|
||||
AuthenticationUtil.popAuthentication();
|
||||
|
||||
this.temporarySites.add(newSite);
|
||||
return newSite;
|
||||
}
|
||||
}
|
@@ -0,0 +1,111 @@
|
||||
/*
|
||||
* 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 static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertNotNull;
|
||||
|
||||
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||
import org.alfresco.repo.transaction.RetryingTransactionHelper;
|
||||
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
||||
import org.alfresco.service.cmr.site.SiteInfo;
|
||||
import org.alfresco.service.cmr.site.SiteService;
|
||||
import org.alfresco.service.cmr.site.SiteVisibility;
|
||||
import org.alfresco.service.namespace.NamespaceService;
|
||||
import org.alfresco.service.namespace.QName;
|
||||
import org.junit.Before;
|
||||
import org.junit.BeforeClass;
|
||||
import org.junit.ClassRule;
|
||||
import org.junit.Rule;
|
||||
import org.junit.Test;
|
||||
import org.junit.rules.RuleChain;
|
||||
|
||||
/**
|
||||
* Test class for {@link TemporarySites}.
|
||||
*
|
||||
* @author Neil McErlean
|
||||
* @since 4.0.3
|
||||
*/
|
||||
public class TemporarySitesTest
|
||||
{
|
||||
// Rule to initialise the default Alfresco spring configuration
|
||||
public static ApplicationContextInit APP_CONTEXT_INIT =
|
||||
ApplicationContextInit.createStandardContextWithOverrides("classpath:sites/test-"
|
||||
+ TemporarySitesTest.class.getSimpleName() + "-context.xml");
|
||||
|
||||
// A rule to manage test sites reused across all the test methods
|
||||
public static TemporaryNodes STATIC_TEST_SITES = new TemporaryNodes(APP_CONTEXT_INIT);
|
||||
|
||||
// Tie them together in a static Rule Chain
|
||||
@ClassRule public static RuleChain ruleChain = RuleChain.outerRule(APP_CONTEXT_INIT)
|
||||
.around(STATIC_TEST_SITES);
|
||||
|
||||
// A rule to manage test sites use in each test method
|
||||
@Rule public TemporarySites testSites = new TemporarySites(APP_CONTEXT_INIT);
|
||||
|
||||
// A rule to allow individual test methods all to be run as "admin".
|
||||
@Rule public RunAsFullyAuthenticatedRule runAsRule = new RunAsFullyAuthenticatedRule(AuthenticationUtil.getAdminUserName());
|
||||
|
||||
// Various services
|
||||
private static NamespaceService NAMESPACE_SERVICE;
|
||||
private static SiteService SITE_SERVICE;
|
||||
private static RetryingTransactionHelper TRANSACTION_HELPER;
|
||||
|
||||
// These SiteInfos are used by the test methods.
|
||||
private SiteInfo testSite1, testSite2;
|
||||
|
||||
@BeforeClass public static void initStaticData() throws Exception
|
||||
{
|
||||
NAMESPACE_SERVICE = APP_CONTEXT_INIT.getApplicationContext().getBean("namespaceService", NamespaceService.class);
|
||||
SITE_SERVICE = APP_CONTEXT_INIT.getApplicationContext().getBean("siteService", SiteService.class);
|
||||
TRANSACTION_HELPER = APP_CONTEXT_INIT.getApplicationContext().getBean("retryingTransactionHelper", RetryingTransactionHelper.class);
|
||||
}
|
||||
|
||||
@Before public void createTestContent()
|
||||
{
|
||||
// Create some test content
|
||||
testSite1 = testSites.createSite("sitePreset", "testSite1", "t", "d", SiteVisibility.PUBLIC, AuthenticationUtil.getAdminUserName());
|
||||
final QName subSiteType = QName.createQName("testsite", "testSubsite", NAMESPACE_SERVICE);
|
||||
testSite2 = testSites.createSite("sitePreset", "testSite2", "T", "D", SiteVisibility.PUBLIC, subSiteType, AuthenticationUtil.getAdminUserName());
|
||||
}
|
||||
|
||||
@Test public void ensureTestSitesWereCreatedOk() throws Exception
|
||||
{
|
||||
TRANSACTION_HELPER.doInTransaction(new RetryingTransactionCallback<Void>()
|
||||
{
|
||||
public Void execute() throws Throwable
|
||||
{
|
||||
final SiteInfo recoveredSite1 = SITE_SERVICE.getSite(testSite1.getShortName());
|
||||
final SiteInfo recoveredSite2 = SITE_SERVICE.getSite(testSite2.getShortName());
|
||||
|
||||
assertNotNull("Test site does not exist", recoveredSite1);
|
||||
assertNotNull("Test site does not exist", recoveredSite2);
|
||||
|
||||
assertEquals("cm:title was wrong", "t", recoveredSite1.getTitle());
|
||||
assertEquals("cm:description was wrong", "d", recoveredSite1.getDescription());
|
||||
assertEquals("preset was wrong", "sitePreset", recoveredSite1.getSitePreset());
|
||||
|
||||
assertEquals("site visibility was wrong", SiteVisibility.PUBLIC, recoveredSite1.getVisibility());
|
||||
|
||||
return null;
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user