Merged V3.2 to HEAD

17307: Merged DEV/BELARUS/V3.2-2009_10_19 to V3.2
       17121: ETHREEOH-2999: Accessing Recent snapshots fails in a web project that is created from an already existing project 
       17223: ETHREEEOH-2999: (post-review changes)
   17346: ETHREEOH-2824 - further perf improvement for multiple single submits (to active workflow sandboxes) from large modified list
   17375: Fix ETHREEOH-1643 - WCM revert file & version history, including a few unreported WCM / UI revert file issues
   17380: ETHREEOH-1643 - fix build/test fallout


git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@18110 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
Jan Vonka
2010-01-19 10:26:45 +00:00
parent bb3c8a1244
commit 8db9d90a72
6 changed files with 116 additions and 53 deletions

View File

@@ -567,10 +567,10 @@
</property> </property>
</bean> </bean>
<!-- deprecated --> <!-- deprecated - note: still used by Web-Client (FileDetailsBean) -->
<bean id="avm-revert-to-version" class="org.alfresco.repo.avm.actions.AVMRevertToVersionAction" parent = "action-executer"> <bean id="avm-revert-to-version" class="org.alfresco.repo.avm.actions.AVMRevertToVersionAction" parent = "action-executer">
<property name="avmService"> <property name="avmService">
<ref bean="AVMService"/> <ref bean="AVMLockingAwareService"/>
</property> </property>
<property name="publicAction"> <property name="publicAction">
<value>false</value> <value>false</value>
@@ -590,7 +590,7 @@
</property> </property>
</bean> </bean>
<!-- deprecated --> <!-- deprecated - note: still used by Web-Client (*Deploy*) -->
<bean id="avm-deploy-website" class="org.alfresco.repo.avm.actions.AVMDeployWebsiteAction" parent="action-executer"> <bean id="avm-deploy-website" class="org.alfresco.repo.avm.actions.AVMDeployWebsiteAction" parent="action-executer">
<!-- Run avm-deploy-website action on the deployment queue --> <!-- Run avm-deploy-website action on the deployment queue -->

View File

@@ -34,6 +34,7 @@ import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.SortedMap; import java.util.SortedMap;
import org.alfresco.repo.avm.util.AVMUtil;
import org.alfresco.repo.domain.PropertyValue; import org.alfresco.repo.domain.PropertyValue;
import org.alfresco.service.cmr.avm.AVMBadArgumentException; import org.alfresco.service.cmr.avm.AVMBadArgumentException;
import org.alfresco.service.cmr.avm.AVMNodeDescriptor; import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
@@ -703,10 +704,11 @@ public class AVMLockingAwareService implements AVMService, ApplicationContextAwa
*/ */
public void removeNode(String parent, String name) public void removeNode(String parent, String name)
{ {
grabLock(parent + '/' + name); String path = AVMUtil.extendAVMPath(parent, name);
grabLock(path);
fService.removeNode(parent, name); fService.removeNode(parent, name);
String[] storePath = parent.split(":"); String[] storePath = parent.split(":");
fService.createSnapshot(storePath[0], null, null); fService.createSnapshot(storePath[0], null, "Removed "+path);
String webProject = getWebProject(storePath[0]); String webProject = getWebProject(storePath[0]);
if (webProject != null) if (webProject != null)
{ {
@@ -722,7 +724,7 @@ public class AVMLockingAwareService implements AVMService, ApplicationContextAwa
grabLock(path); grabLock(path);
fService.removeNode(path); fService.removeNode(path);
String[] storePath = path.split(":"); String[] storePath = path.split(":");
fService.createSnapshot(storePath[0], null, null); fService.createSnapshot(storePath[0], null, "Removed "+path);
String webProject = getWebProject(storePath[0]); String webProject = getWebProject(storePath[0]);
if (webProject != null) if (webProject != null)
{ {

View File

@@ -1259,47 +1259,62 @@ public class AVMServiceTest extends AVMServiceTestBase
try try
{ {
setupBasicTree(); setupBasicTree();
ContentWriter writer = fService.getContentWriter("main:/a/b/c/foo"); ContentWriter writer = fService.getContentWriter("main:/a/b/c/foo");
writer.setEncoding("UTF-8"); writer.setEncoding("UTF-8");
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN); writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
writer.putContent("I am main:/a/b/c/foo V1"); writer.putContent("I am main:/a/b/c/foo V1");
fService.createSnapshot("main", "v1", null); fService.createSnapshot("main", "v1", null);
writer = fService.getContentWriter("main:/a/b/c/foo"); writer = fService.getContentWriter("main:/a/b/c/foo");
writer.setEncoding("UTF-8"); writer.setEncoding("UTF-8");
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN); writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
writer.putContent("I am main:/a/b/c/foo V2"); writer.putContent("I am main:/a/b/c/foo V2");
fService.createSnapshot("main", "v2", null); fService.createSnapshot("main", "v2", null);
writer = fService.getContentWriter("main:/a/b/c/foo"); writer = fService.getContentWriter("main:/a/b/c/foo");
writer.setEncoding("UTF-8"); writer.setEncoding("UTF-8");
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN); writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
writer.putContent("I am main:/a/b/c/foo V3"); writer.putContent("I am main:/a/b/c/foo V3");
fService.createSnapshot("main", "v3", null); fService.createSnapshot("main", "v3", null);
writer = fService.getContentWriter("main:/a/b/c/foo"); writer = fService.getContentWriter("main:/a/b/c/foo");
writer.setEncoding("UTF-8"); writer.setEncoding("UTF-8");
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN); writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
writer.putContent("I am main:/a/b/c/foo V4"); writer.putContent("I am main:/a/b/c/foo V4");
fService.createSnapshot("main", "v4", null); fService.createSnapshot("main", "v4", null);
writer = fService.getContentWriter("main:/a/b/c/foo"); writer = fService.getContentWriter("main:/a/b/c/foo");
writer.setEncoding("UTF-8"); writer.setEncoding("UTF-8");
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN); writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
writer.putContent("I am main:/a/b/c/foo V5"); writer.putContent("I am main:/a/b/c/foo V5");
fService.createSnapshot("main", "v5", null); fService.createSnapshot("main", "v5", null);
writer = fService.getContentWriter("main:/a/b/c/foo"); writer = fService.getContentWriter("main:/a/b/c/foo");
writer.setEncoding("UTF-8"); writer.setEncoding("UTF-8");
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN); writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
writer.putContent("I am main:/a/b/c/foo HEAD"); writer.putContent("I am main:/a/b/c/foo HEAD");
StoreRef storeRef = AVMNodeConverter.ToStoreRef("main"); StoreRef storeRef = AVMNodeConverter.ToStoreRef("main");
SearchService searchService = fIndexerAndSearcher.getSearcher(storeRef, true); SearchService searchService = fIndexerAndSearcher.getSearcher(storeRef, true);
ResultSet results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\""); ResultSet results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\"");
assertEquals(0, results.length()); assertEquals(0, results.length());
results.close(); results.close();
results = searchService.query(storeRef, "lucene", "TEXT:\"V5\""); results = searchService.query(storeRef, "lucene", "TEXT:\"V5\"");
assertEquals(1, results.length()); assertEquals(1, results.length());
results.close(); results.close();
results = searchService.query(storeRef, "lucene", "TEXT:\"V2\"");
assertEquals(0, results.length());
results.close();
AVMNodeDescriptor desc = fService.lookup(-1, "main:/a/b/c/foo"); AVMNodeDescriptor desc = fService.lookup(-1, "main:/a/b/c/foo");
List<AVMNodeDescriptor> history = fService.getHistory(desc, 100); List<AVMNodeDescriptor> history = fService.getHistory(desc, 100);
AVMNodeDescriptor toRevert = history.get(3); AVMNodeDescriptor toRevert = history.get(3);
final ActionImpl action = new ActionImpl(null, GUID.generate(), AVMRevertToVersionAction.NAME); final ActionImpl action = new ActionImpl(null, GUID.generate(), AVMRevertToVersionAction.NAME);
action.setParameterValue(AVMRevertToVersionAction.TOREVERT, toRevert); action.setParameterValue(AVMRevertToVersionAction.TOREVERT, toRevert);
final AVMRevertToVersionAction revert = (AVMRevertToVersionAction) fContext.getBean("avm-revert-to-version"); final AVMRevertToVersionAction revert = (AVMRevertToVersionAction) fContext.getBean("avm-revert-to-version");
@@ -1307,26 +1322,15 @@ public class AVMServiceTest extends AVMServiceTestBase
{ {
public Object execute() throws Exception public Object execute() throws Exception
{ {
// note: including implicit snapshot
revert.execute(action, AVMNodeConverter.ToNodeRef(-1, "main:/a/b/c/foo")); revert.execute(action, AVMNodeConverter.ToNodeRef(-1, "main:/a/b/c/foo"));
return null; return null;
} }
} };
;
TransactionService transactionService = (TransactionService) fContext.getBean("transactionService"); TransactionService transactionService = (TransactionService) fContext.getBean("transactionService");
transactionService.getRetryingTransactionHelper().doInTransaction(new TxnWork()); transactionService.getRetryingTransactionHelper().doInTransaction(new TxnWork());
results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\"");
assertEquals(0, results.length());
results.close();
results = searchService.query(storeRef, "lucene", "TEXT:\"V5\"");
assertEquals(1, results.length());
results.close();
results = searchService.query(storeRef, "lucene", "TEXT:\"V2\"");
assertEquals(0, results.length());
results.close();
fService.createSnapshot("main", "reverted", null);
results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\""); results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\"");
assertEquals(0, results.length()); assertEquals(0, results.length());
results.close(); results.close();
@@ -1336,7 +1340,6 @@ public class AVMServiceTest extends AVMServiceTestBase
results = searchService.query(storeRef, "lucene", "TEXT:\"V2\""); results = searchService.query(storeRef, "lucene", "TEXT:\"V2\"");
assertEquals(1, results.length()); assertEquals(1, results.length());
results.close(); results.close();
} }
catch (Exception e) catch (Exception e)
{ {

View File

@@ -29,6 +29,7 @@ import java.util.List;
import org.alfresco.repo.action.ParameterDefinitionImpl; import org.alfresco.repo.action.ParameterDefinitionImpl;
import org.alfresco.repo.action.executer.ActionExecuterAbstractBase; import org.alfresco.repo.action.executer.ActionExecuterAbstractBase;
import org.alfresco.repo.avm.AVMNodeConverter; import org.alfresco.repo.avm.AVMNodeConverter;
import org.alfresco.repo.avm.util.AVMUtil;
import org.alfresco.service.cmr.action.Action; import org.alfresco.service.cmr.action.Action;
import org.alfresco.service.cmr.action.ParameterDefinition; import org.alfresco.service.cmr.action.ParameterDefinition;
import org.alfresco.service.cmr.avm.AVMNodeDescriptor; import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
@@ -77,9 +78,12 @@ public class AVMRevertToVersionAction extends ActionExecuterAbstractBase
{ {
Pair<Integer, String> versionPath = Pair<Integer, String> versionPath =
AVMNodeConverter.ToAVMVersionPath(actionedUponNodeRef); AVMNodeConverter.ToAVMVersionPath(actionedUponNodeRef);
AVMNodeDescriptor toRevert = AVMNodeDescriptor toRevertTo =
(AVMNodeDescriptor)action.getParameterValue(TOREVERT); (AVMNodeDescriptor)action.getParameterValue(TOREVERT);
fAVMService.revert(versionPath.getSecond(), toRevert); fAVMService.revert(versionPath.getSecond(), toRevertTo);
String[] storePath = AVMUtil.splitPath(versionPath.getSecond());
fAVMService.createSnapshot(storePath[0], null, "Reverted "+versionPath.getSecond()+" to version "+toRevertTo.getVersionID());
} }
/* (non-Javadoc) /* (non-Javadoc)

View File

@@ -961,30 +961,28 @@ public class SandboxServiceImpl implements SandboxService
List<AssetInfo> assetsToRevert = new ArrayList<AssetInfo>(assets.size()); List<AssetInfo> assetsToRevert = new ArrayList<AssetInfo>(assets.size());
List<WorkflowTask> tasks = null; List<String> wfRelativePaths = WCMWorkflowUtil.getAssociatedPathsForSandbox(avmSyncService, workflowService, sbStoreId);
for (AssetInfo asset : assets) for (AssetInfo asset : assets)
{ {
if (tasks == null) if (! asset.getSandboxId().equals(sbStoreId))
{ {
tasks = WCMWorkflowUtil.getAssociatedTasksForSandbox(workflowService, WCMUtil.getSandboxStoreId(asset.getAvmPath())); // belts-and-braces
logger.warn("revertListAssets: Skip assert "+asset.getPath()+" (was "+asset.getSandboxId()+", expected "+sbStoreId+")");
continue;
} }
// TODO refactor getAssociatedTasksForNode to use AssetInfo instead of AVMNodeDescriptor // check if in workflow
AVMNodeDescriptor node = ((AssetInfoImpl)asset).getAVMNodeDescriptor(); if (! wfRelativePaths.contains(asset.getPath()))
if (node != null)
{ {
if (WCMWorkflowUtil.getAssociatedTasksForNode(avmService, node, tasks).size() == 0) assetsToRevert.add(asset);
{
assetsToRevert.add(asset); if (VirtServerUtils.requiresUpdateNotification(asset.getAvmPath()))
{
if (VirtServerUtils.requiresUpdateNotification(asset.getAvmPath())) // Bind the post-commit transaction listener with data required for virtualization server notification
{ UpdateSandboxTransactionListener tl = new UpdateSandboxTransactionListener(asset.getAvmPath());
// Bind the post-commit transaction listener with data required for virtualization server notification AlfrescoTransactionSupport.bindListener(tl);
UpdateSandboxTransactionListener tl = new UpdateSandboxTransactionListener(asset.getAvmPath()); }
AlfrescoTransactionSupport.bindListener(tl);
}
}
} }
} }

View File

@@ -24,6 +24,7 @@
*/ */
package org.alfresco.wcm.util; package org.alfresco.wcm.util;
import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
@@ -36,6 +37,8 @@ import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
import org.alfresco.service.cmr.avm.AVMNotFoundException; import org.alfresco.service.cmr.avm.AVMNotFoundException;
import org.alfresco.service.cmr.avm.AVMService; import org.alfresco.service.cmr.avm.AVMService;
import org.alfresco.service.cmr.avm.LayeringDescriptor; import org.alfresco.service.cmr.avm.LayeringDescriptor;
import org.alfresco.service.cmr.avmsync.AVMDifference;
import org.alfresco.service.cmr.avmsync.AVMSyncService;
import org.alfresco.service.cmr.dictionary.DataTypeDefinition; import org.alfresco.service.cmr.dictionary.DataTypeDefinition;
import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.cmr.repository.NodeRef;
import org.alfresco.service.cmr.workflow.WorkflowService; import org.alfresco.service.cmr.workflow.WorkflowService;
@@ -56,7 +59,7 @@ import org.apache.commons.logging.LogFactory;
public class WCMWorkflowUtil public class WCMWorkflowUtil
{ {
private static final Log logger = LogFactory.getLog(WCMWorkflowUtil.class); private static final Log logger = LogFactory.getLog(WCMWorkflowUtil.class);
public static NodeRef createWorkflowPackage(WorkflowService workflowService, AVMService avmService, SandboxInfo sandboxInfo) public static NodeRef createWorkflowPackage(WorkflowService workflowService, AVMService avmService, SandboxInfo sandboxInfo)
{ {
// create package paths (layered to user sandbox area as target) // create package paths (layered to user sandbox area as target)
@@ -81,25 +84,30 @@ public class WCMWorkflowUtil
public static List<WorkflowTask> getAssociatedTasksForSandbox(WorkflowService workflowService, final String storeName) public static List<WorkflowTask> getAssociatedTasksForSandbox(WorkflowService workflowService, final String storeName)
{ {
long start = System.currentTimeMillis();
String fromPath = WCMUtil.buildStoreRootPath(storeName); String fromPath = WCMUtil.buildStoreRootPath(storeName);
WorkflowTaskQuery query = new WorkflowTaskQuery(); WorkflowTaskQuery query = new WorkflowTaskQuery();
HashMap<QName, Object> props = new HashMap<QName, Object>(1, 1.0f); HashMap<QName, Object> props = new HashMap<QName, Object>(1, 1.0f);
props.put(WCMWorkflowModel.PROP_FROM_PATH, fromPath); props.put(WCMWorkflowModel.PROP_FROM_PATH, fromPath);
query.setProcessCustomProps(props); query.setProcessCustomProps(props);
query.setActive(true); query.setActive(true);
List<WorkflowTask> tasks = workflowService.queryTasks(query); List<WorkflowTask> tasks = workflowService.queryTasks(query);
if (logger.isDebugEnabled()) if (logger.isTraceEnabled())
{ {
logger.debug("found " + tasks.size() + " tasks originating user sandbox " + fromPath); logger.trace("getAssociatedTasksForSandbox: "+storeName+" (found "+tasks.size()+" tasks originating user sandbox "+fromPath+") in "+(System.currentTimeMillis()-start)+" msecs");
} }
return tasks; return tasks;
} }
/**
* @deprecated since 3.2
*/
public static List<WorkflowTask> getAssociatedTasksForNode(AVMService avmService, AVMNodeDescriptor node, List<WorkflowTask> tasks) public static List<WorkflowTask> getAssociatedTasksForNode(AVMService avmService, AVMNodeDescriptor node, List<WorkflowTask> tasks)
{ {
List<WorkflowTask> result = new LinkedList<WorkflowTask>(); List<WorkflowTask> result = new LinkedList<WorkflowTask>();
@@ -139,10 +147,58 @@ public class WCMWorkflowUtil
return result; return result;
} }
/**
* @deprecated since 3.2
*/
public static List<WorkflowTask> getAssociatedTasksForNode(WorkflowService workflowService, AVMService avmService, AVMNodeDescriptor node) public static List<WorkflowTask> getAssociatedTasksForNode(WorkflowService workflowService, AVMService avmService, AVMNodeDescriptor node)
{ {
final List<WorkflowTask> tasks = WCMWorkflowUtil.getAssociatedTasksForSandbox(workflowService, WCMUtil.getSandboxStoreId(node.getPath())); final List<WorkflowTask> tasks = getAssociatedTasksForSandbox(workflowService, WCMUtil.getSandboxStoreId(node.getPath()));
return getAssociatedTasksForNode(avmService, node, tasks); return getAssociatedTasksForNode(avmService, node, tasks);
} }
public static List<String> getAssociatedPathsForSandbox(AVMSyncService avmSyncService, WorkflowService workflowService, String sandboxName)
{
long start = System.currentTimeMillis();
List<WorkflowTask> tasks = getAssociatedTasksForSandbox(workflowService, sandboxName);
List<String> storeRelativePaths = getAssociatedPathsForSandboxTasks(avmSyncService, sandboxName, tasks);
if (logger.isDebugEnabled())
{
logger.debug("getAssociatedPathsForSandbox: "+sandboxName+" (tasks="+tasks.size()+", paths="+storeRelativePaths.size()+") in "+(System.currentTimeMillis()-start)+" msecs");
}
return storeRelativePaths;
}
private static List<String> getAssociatedPathsForSandboxTasks(AVMSyncService avmSyncService, String sandboxName, List<WorkflowTask> tasks)
{
long start = System.currentTimeMillis();
String stagingSandboxName = WCMUtil.buildStagingStoreName(WCMUtil.getWebProjectStoreId(sandboxName));
List<String> storeRelativePaths = new ArrayList<String>(tasks.size());
for (WorkflowTask task : tasks)
{
final NodeRef ref = task.path.instance.workflowPackage;
String wfPath = AVMNodeConverter.ToAVMVersionPath(ref).getSecond();
String stagingSandboxPath = WCMUtil.getCorrespondingPath(wfPath, stagingSandboxName);
List<AVMDifference> diffs = avmSyncService.compare(-1, wfPath, -1, stagingSandboxPath, null);
for (AVMDifference diff : diffs)
{
storeRelativePaths.add(WCMUtil.getStoreRelativePath(diff.getSourcePath()));
}
}
if (logger.isTraceEnabled())
{
logger.trace("getAssociatedPathsForSandboxTasks: "+sandboxName+" (tasks="+tasks.size()+", paths="+storeRelativePaths.size()+") in "+(System.currentTimeMillis()-start)+" msecs");
}
return storeRelativePaths;
}
} }