mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-31 17:39:05 +00:00
RM-1639 (Recordable Version Configuration Rule)
* Refactored code (added recordable version config service) git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/modules/recordsmanagement/HEAD@89727 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -1581,4 +1581,49 @@
|
|||||||
</value>
|
</value>
|
||||||
</property>
|
</property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
|
<!-- Recordable Verison Config Service -->
|
||||||
|
|
||||||
|
<bean id="recordableVersionConfigService" class="org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigServiceImpl">
|
||||||
|
<property name="nodeService" ref="NodeService"/>
|
||||||
|
</bean>
|
||||||
|
|
||||||
|
<bean id="RecordableVersionConfigService" class="org.springframework.aop.framework.ProxyFactoryBean">
|
||||||
|
<property name="proxyInterfaces">
|
||||||
|
<value>org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigService</value>
|
||||||
|
</property>
|
||||||
|
<property name="target">
|
||||||
|
<ref bean="recordableVersionConfigService"/>
|
||||||
|
</property>
|
||||||
|
<property name="interceptorNames">
|
||||||
|
<list>
|
||||||
|
<idref local="RecordableVersionConfigService_transaction"/>
|
||||||
|
<idref bean="exceptionTranslator"/>
|
||||||
|
<idref local="RecordableVersionConfigService_security"/>
|
||||||
|
</list>
|
||||||
|
</property>
|
||||||
|
</bean>
|
||||||
|
|
||||||
|
<bean id="RecordableVersionConfigService_transaction" class="org.springframework.transaction.interceptor.TransactionInterceptor">
|
||||||
|
<property name="transactionManager">
|
||||||
|
<ref bean="transactionManager"/>
|
||||||
|
</property>
|
||||||
|
<property name="transactionAttributes">
|
||||||
|
<props>
|
||||||
|
<prop key="*">${server.transaction.mode.default}</prop>
|
||||||
|
</props>
|
||||||
|
</property>
|
||||||
|
</bean>
|
||||||
|
|
||||||
|
<bean id="RecordableVersionConfigService_security" parent="baseSecurity">
|
||||||
|
<property name="objectDefinitionSource">
|
||||||
|
<value>
|
||||||
|
<![CDATA[
|
||||||
|
org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigService.getVersions=RM_ALLOW
|
||||||
|
org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigService.setVersion=RM_ALLOW
|
||||||
|
org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigService.*=RM_DENY
|
||||||
|
]]>
|
||||||
|
</value>
|
||||||
|
</property>
|
||||||
|
</bean>
|
||||||
</beans>
|
</beans>
|
||||||
|
@@ -618,11 +618,13 @@
|
|||||||
<bean id="webscript.org.alfresco.slingshot.documentlibrary.action.recorded-version-config.post"
|
<bean id="webscript.org.alfresco.slingshot.documentlibrary.action.recorded-version-config.post"
|
||||||
class="org.alfresco.module.org_alfresco_module_rm.script.slingshot.RecordedVersionConfigPost"
|
class="org.alfresco.module.org_alfresco_module_rm.script.slingshot.RecordedVersionConfigPost"
|
||||||
parent="rmBaseWebscript">
|
parent="rmBaseWebscript">
|
||||||
|
<property name="RecordableVersionConfigService" ref="RecordableVersionConfigService" />
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<!-- REST impl for GET recorded version config -->
|
<!-- REST impl for GET recorded version config -->
|
||||||
<bean id="webscript.org.alfresco.slingshot.documentlibrary.action.recorded-version-config.get"
|
<bean id="webscript.org.alfresco.slingshot.documentlibrary.action.recorded-version-config.get"
|
||||||
class="org.alfresco.module.org_alfresco_module_rm.script.slingshot.RecordedVersionConfigGet"
|
class="org.alfresco.module.org_alfresco_module_rm.script.slingshot.RecordedVersionConfigGet"
|
||||||
parent="rmBaseWebscript">
|
parent="rmBaseWebscript">
|
||||||
|
<property name="RecordableVersionConfigService" ref="RecordableVersionConfigService" />
|
||||||
</bean>
|
</bean>
|
||||||
</beans>
|
</beans>
|
@@ -0,0 +1,49 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2005-2014 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.module.org_alfresco_module_rm.recordableversion;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.script.slingshot.Version;
|
||||||
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Recordable version config service interface
|
||||||
|
*
|
||||||
|
* @author Tuna Aksoy
|
||||||
|
* @since 2.3
|
||||||
|
*/
|
||||||
|
public interface RecordableVersionConfigService
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Gets the recordable versions
|
||||||
|
*
|
||||||
|
* @param nodeRef The node reference for which the recordable versions should be retrieved
|
||||||
|
* @return The list of recordable versions
|
||||||
|
*/
|
||||||
|
List<Version> getVersions(NodeRef nodeRef);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the recordable version for the given node
|
||||||
|
*
|
||||||
|
* @param nodeRef The node reference for which the recorable version should be set
|
||||||
|
* @param version The version to be set
|
||||||
|
*/
|
||||||
|
void setVersion(NodeRef nodeRef, String version);
|
||||||
|
}
|
@@ -0,0 +1,127 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2005-2014 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.module.org_alfresco_module_rm.recordableversion;
|
||||||
|
|
||||||
|
import static org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy.NONE;
|
||||||
|
import static org.alfresco.util.ParameterCheck.mandatory;
|
||||||
|
import static org.alfresco.util.ParameterCheck.mandatoryString;
|
||||||
|
import static org.apache.commons.lang.StringUtils.isNotBlank;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.script.slingshot.Version;
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionModel;
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy;
|
||||||
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
|
import org.alfresco.service.cmr.repository.NodeService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Recordable version config service
|
||||||
|
*
|
||||||
|
* @author Tuna Aksoy
|
||||||
|
* @since 2.3
|
||||||
|
*/
|
||||||
|
public class RecordableVersionConfigServiceImpl implements RecordableVersionConfigService, RecordableVersionModel
|
||||||
|
{
|
||||||
|
/** Node service */
|
||||||
|
private NodeService nodeService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the node service
|
||||||
|
*
|
||||||
|
* @return The node service
|
||||||
|
*/
|
||||||
|
protected NodeService getNodeService()
|
||||||
|
{
|
||||||
|
return this.nodeService;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the node service
|
||||||
|
*
|
||||||
|
* @param nodeService The node service
|
||||||
|
*/
|
||||||
|
public void setNodeService(NodeService nodeService)
|
||||||
|
{
|
||||||
|
this.nodeService = nodeService;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigService#getVersions(org.alfresco.service.cmr.repository.NodeRef)
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public List<Version> getVersions(NodeRef nodeRef)
|
||||||
|
{
|
||||||
|
mandatory("nodeRef", nodeRef);
|
||||||
|
|
||||||
|
RecordableVersionPolicy[] recordableVersionPolicies = RecordableVersionPolicy.values();
|
||||||
|
List<Version> versions = new ArrayList<Version>(recordableVersionPolicies.length);
|
||||||
|
|
||||||
|
for (RecordableVersionPolicy recordableVersionPolicy : recordableVersionPolicies)
|
||||||
|
{
|
||||||
|
String policy = recordableVersionPolicy.toString();
|
||||||
|
boolean selected = isVersionPolicySelected(recordableVersionPolicy, nodeRef);
|
||||||
|
versions.add(new Version(policy, selected));
|
||||||
|
}
|
||||||
|
|
||||||
|
return versions;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigService#setVersion(org.alfresco.service.cmr.repository.NodeRef, java.lang.String)
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void setVersion(NodeRef nodeRef, String version)
|
||||||
|
{
|
||||||
|
mandatory("nodeRef", nodeRef);
|
||||||
|
mandatoryString("recordedVersion", version);
|
||||||
|
|
||||||
|
RecordableVersionPolicy recordableVersionPolicy = RecordableVersionPolicy.valueOf(version);
|
||||||
|
getNodeService().setProperty(nodeRef, PROP_RECORDABLE_VERSION_POLICY, recordableVersionPolicy);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks if the specified recordable version policy has been selected for the document
|
||||||
|
*
|
||||||
|
* @param recordableVersionPolicy The recordable version policy
|
||||||
|
* @param nodeRef Node reference of the document
|
||||||
|
* @return <code>true</code> if the specified recordable version policy has been selected for the document, <code>false</code> otherwise
|
||||||
|
*/
|
||||||
|
private boolean isVersionPolicySelected(RecordableVersionPolicy recordableVersionPolicy, NodeRef nodeRef)
|
||||||
|
{
|
||||||
|
boolean isVersionPolicySelected = false;
|
||||||
|
String policy = (String) getNodeService().getProperty(nodeRef, PROP_RECORDABLE_VERSION_POLICY);
|
||||||
|
if (isNotBlank(policy))
|
||||||
|
{
|
||||||
|
if (RecordableVersionPolicy.valueOf(policy).equals(recordableVersionPolicy))
|
||||||
|
{
|
||||||
|
isVersionPolicySelected = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (recordableVersionPolicy.equals(NONE))
|
||||||
|
{
|
||||||
|
isVersionPolicySelected = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return isVersionPolicySelected;
|
||||||
|
}
|
||||||
|
}
|
@@ -18,16 +18,13 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.module.org_alfresco_module_rm.script.slingshot;
|
package org.alfresco.module.org_alfresco_module_rm.script.slingshot;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.script.AbstractRmWebScript;
|
import org.alfresco.module.org_alfresco_module_rm.script.AbstractRmWebScript;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionModel;
|
|
||||||
import org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy;
|
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.apache.commons.lang.StringUtils;
|
|
||||||
import org.springframework.extensions.webscripts.Cache;
|
import org.springframework.extensions.webscripts.Cache;
|
||||||
import org.springframework.extensions.webscripts.Status;
|
import org.springframework.extensions.webscripts.Status;
|
||||||
import org.springframework.extensions.webscripts.WebScriptRequest;
|
import org.springframework.extensions.webscripts.WebScriptRequest;
|
||||||
@@ -38,68 +35,41 @@ import org.springframework.extensions.webscripts.WebScriptRequest;
|
|||||||
* @author Tuna Aksoy
|
* @author Tuna Aksoy
|
||||||
* @since 2.3
|
* @since 2.3
|
||||||
*/
|
*/
|
||||||
public class RecordedVersionConfigGet extends AbstractRmWebScript implements RecordableVersionModel
|
public class RecordedVersionConfigGet extends AbstractRmWebScript
|
||||||
{
|
{
|
||||||
|
/** Recordable version config service */
|
||||||
|
private RecordableVersionConfigService recordableVersionConfigService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the recordable version config service
|
||||||
|
*
|
||||||
|
* @return The recordable version config service
|
||||||
|
*/
|
||||||
|
protected RecordableVersionConfigService getRecordableVersionConfigService()
|
||||||
|
{
|
||||||
|
return this.recordableVersionConfigService;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the recordable version config service
|
||||||
|
*
|
||||||
|
* @param recordableVersionConfigService The recordable version config service
|
||||||
|
*/
|
||||||
|
public void setRecordableVersionConfigService(RecordableVersionConfigService recordableVersionConfigService)
|
||||||
|
{
|
||||||
|
this.recordableVersionConfigService = recordableVersionConfigService;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see org.alfresco.web.scripts.DeclarativeWebScript#executeImpl(org.alfresco.web.scripts.WebScriptRequest, org.alfresco.web.scripts.Status, org.alfresco.web.scripts.Cache)
|
* @see org.alfresco.web.scripts.DeclarativeWebScript#executeImpl(org.alfresco.web.scripts.WebScriptRequest, org.alfresco.web.scripts.Status, org.alfresco.web.scripts.Cache)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
protected Map<String, Object> executeImpl(WebScriptRequest req, Status status, Cache cache)
|
protected Map<String, Object> executeImpl(WebScriptRequest req, Status status, Cache cache)
|
||||||
{
|
{
|
||||||
RecordableVersionPolicy[] recordableVersionPolicies = RecordableVersionPolicy.values();
|
|
||||||
List<Map<String, Object>> recordableVersions = new ArrayList<Map<String,Object>>(recordableVersionPolicies.length);
|
|
||||||
NodeRef documentNodeRef = parseRequestForNodeRef(req);
|
|
||||||
|
|
||||||
for (RecordableVersionPolicy recordableVersionPolicy : recordableVersionPolicies)
|
|
||||||
{
|
|
||||||
recordableVersions.add(buildRecordableVersionData(recordableVersionPolicy, documentNodeRef));
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, Object> model = new HashMap<String, Object>(1);
|
Map<String, Object> model = new HashMap<String, Object>(1);
|
||||||
|
NodeRef nodeRef = parseRequestForNodeRef(req);
|
||||||
|
List<Version> recordableVersions = getRecordableVersionConfigService().getVersions(nodeRef);
|
||||||
model.put("recordableVersions", recordableVersions);
|
model.put("recordableVersions", recordableVersions);
|
||||||
return model;
|
return model;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Builds the recordable version data
|
|
||||||
*
|
|
||||||
* @param recordableVersionPolicy The recordable version policy
|
|
||||||
* @param nodeRef Node reference of the document
|
|
||||||
* @return A map containing the information about recordable version policy and if this policy is selected for the document
|
|
||||||
*/
|
|
||||||
private Map<String, Object> buildRecordableVersionData(RecordableVersionPolicy recordableVersionPolicy, NodeRef nodeRef)
|
|
||||||
{
|
|
||||||
Map<String, Object> recordableVersionData = new HashMap<String, Object>(2);
|
|
||||||
recordableVersionData.put("policy", recordableVersionPolicy.toString());
|
|
||||||
recordableVersionData.put("selected", isVersionPolicySelected(recordableVersionPolicy, nodeRef));
|
|
||||||
return recordableVersionData;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks if the specified recordable version policy has been selected for the document
|
|
||||||
*
|
|
||||||
* @param recordableVersionPolicy The recordable version policy
|
|
||||||
* @param nodeRef Node reference of the document
|
|
||||||
* @return <code>true</code> if the specified recordable version policy has been selected for the document, <code>false</code> otherwise
|
|
||||||
*/
|
|
||||||
private boolean isVersionPolicySelected(RecordableVersionPolicy recordableVersionPolicy, NodeRef nodeRef)
|
|
||||||
{
|
|
||||||
boolean isVersionPolicySelected = false;
|
|
||||||
String policy = (String) getNodeService().getProperty(nodeRef, PROP_RECORDABLE_VERSION_POLICY);
|
|
||||||
if (StringUtils.isNotBlank(policy))
|
|
||||||
{
|
|
||||||
if (RecordableVersionPolicy.valueOf(policy).equals(recordableVersionPolicy))
|
|
||||||
{
|
|
||||||
isVersionPolicySelected = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (recordableVersionPolicy.equals(RecordableVersionPolicy.NONE))
|
|
||||||
{
|
|
||||||
isVersionPolicySelected = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return isVersionPolicySelected;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@@ -24,9 +24,8 @@ import static org.alfresco.util.WebScriptUtils.getStringValueFromJSONObject;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.script.AbstractRmWebScript;
|
import org.alfresco.module.org_alfresco_module_rm.script.AbstractRmWebScript;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionModel;
|
|
||||||
import org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy;
|
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
import org.springframework.extensions.webscripts.Cache;
|
import org.springframework.extensions.webscripts.Cache;
|
||||||
@@ -39,11 +38,34 @@ import org.springframework.extensions.webscripts.WebScriptRequest;
|
|||||||
* @author Tuna Aksoy
|
* @author Tuna Aksoy
|
||||||
* @since 2.3
|
* @since 2.3
|
||||||
*/
|
*/
|
||||||
public class RecordedVersionConfigPost extends AbstractRmWebScript implements RecordableVersionModel
|
public class RecordedVersionConfigPost extends AbstractRmWebScript
|
||||||
{
|
{
|
||||||
// Constant for recorded version parameter
|
/** Constant for recorded version parameter */
|
||||||
public static final String RECORDED_VERSION = "recordedVersion";
|
public static final String RECORDED_VERSION = "recordedVersion";
|
||||||
|
|
||||||
|
/** Recordable version config service */
|
||||||
|
private RecordableVersionConfigService recordableVersionConfigService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the recordable version config service
|
||||||
|
*
|
||||||
|
* @return The recordable version config service
|
||||||
|
*/
|
||||||
|
protected RecordableVersionConfigService getRecordableVersionConfigService()
|
||||||
|
{
|
||||||
|
return this.recordableVersionConfigService;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the recordable version config service
|
||||||
|
*
|
||||||
|
* @param recordableVersionConfigService The recordable version config service
|
||||||
|
*/
|
||||||
|
public void setRecordableVersionConfigService(RecordableVersionConfigService recordableVersionConfigService)
|
||||||
|
{
|
||||||
|
this.recordableVersionConfigService = recordableVersionConfigService;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see org.alfresco.web.scripts.DeclarativeWebScript#executeImpl(org.alfresco.web.scripts.WebScriptRequest, org.alfresco.web.scripts.Status, org.alfresco.web.scripts.Cache)
|
* @see org.alfresco.web.scripts.DeclarativeWebScript#executeImpl(org.alfresco.web.scripts.WebScriptRequest, org.alfresco.web.scripts.Status, org.alfresco.web.scripts.Cache)
|
||||||
*/
|
*/
|
||||||
@@ -51,8 +73,8 @@ public class RecordedVersionConfigPost extends AbstractRmWebScript implements Re
|
|||||||
protected Map<String, Object> executeImpl(WebScriptRequest req, Status status, Cache cache)
|
protected Map<String, Object> executeImpl(WebScriptRequest req, Status status, Cache cache)
|
||||||
{
|
{
|
||||||
NodeRef nodeRef = parseRequestForNodeRef(req);
|
NodeRef nodeRef = parseRequestForNodeRef(req);
|
||||||
RecordableVersionPolicy recordableVersionPolicy = getRecordableVersionPolicy(req);
|
String policy = getRecordableVersionPolicy(req);
|
||||||
getNodeService().setProperty(nodeRef, PROP_RECORDABLE_VERSION_POLICY, recordableVersionPolicy);
|
getRecordableVersionConfigService().setVersion(nodeRef, policy);
|
||||||
return new HashMap<String, Object>(1);
|
return new HashMap<String, Object>(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -62,10 +84,9 @@ public class RecordedVersionConfigPost extends AbstractRmWebScript implements Re
|
|||||||
* @param The webscript request
|
* @param The webscript request
|
||||||
* @return The recordable version policy
|
* @return The recordable version policy
|
||||||
*/
|
*/
|
||||||
private RecordableVersionPolicy getRecordableVersionPolicy(WebScriptRequest req)
|
private String getRecordableVersionPolicy(WebScriptRequest req)
|
||||||
{
|
{
|
||||||
JSONObject requestContent = getRequestContentAsJsonObject(req);
|
JSONObject requestContent = getRequestContentAsJsonObject(req);
|
||||||
String recordedVersion = getStringValueFromJSONObject(requestContent, RECORDED_VERSION);
|
return getStringValueFromJSONObject(requestContent, RECORDED_VERSION);
|
||||||
return RecordableVersionPolicy.valueOf(recordedVersion);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -0,0 +1,92 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2005-2014 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.module.org_alfresco_module_rm.script.slingshot;
|
||||||
|
|
||||||
|
import static org.alfresco.util.ParameterCheck.mandatory;
|
||||||
|
import static org.alfresco.util.ParameterCheck.mandatoryString;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Recordable version class
|
||||||
|
*
|
||||||
|
* @author Tuna Aksoy
|
||||||
|
* @since 2.3
|
||||||
|
*/
|
||||||
|
public class Version
|
||||||
|
{
|
||||||
|
/** The version policy */
|
||||||
|
private String policy;
|
||||||
|
|
||||||
|
/** Is the version selected */
|
||||||
|
private boolean selected;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @param policy The version policy
|
||||||
|
* @param selected Is the version selected
|
||||||
|
*/
|
||||||
|
public Version(String policy, boolean selected)
|
||||||
|
{
|
||||||
|
mandatoryString("policy", policy);
|
||||||
|
mandatory("selected", selected);
|
||||||
|
|
||||||
|
setPolicy(policy);
|
||||||
|
setSelected(selected);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the version policy
|
||||||
|
*
|
||||||
|
* @return The version policy
|
||||||
|
*/
|
||||||
|
public String getPolicy()
|
||||||
|
{
|
||||||
|
return this.policy;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the version policy
|
||||||
|
*
|
||||||
|
* @param policy The version policy
|
||||||
|
*/
|
||||||
|
private void setPolicy(String policy)
|
||||||
|
{
|
||||||
|
this.policy = policy;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Is the version selected
|
||||||
|
*
|
||||||
|
* @return <code>true</code> if the version is selected, <code>false</code> otherwise
|
||||||
|
*/
|
||||||
|
public boolean isSelected()
|
||||||
|
{
|
||||||
|
return this.selected;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the version as selected
|
||||||
|
*
|
||||||
|
* @param selected <code>true</code> if the version should be selected, <code>false</code> otherwise
|
||||||
|
*/
|
||||||
|
private void setSelected(boolean selected)
|
||||||
|
{
|
||||||
|
this.selected = selected;
|
||||||
|
}
|
||||||
|
}
|
@@ -38,7 +38,7 @@ public abstract class BaseRecordedVersionConfigTest extends BaseWebScriptUnitTes
|
|||||||
/** Node ref for test document */
|
/** Node ref for test document */
|
||||||
protected NodeRef testdoc;
|
protected NodeRef testdoc;
|
||||||
|
|
||||||
/** setup web script parameters */
|
/** Setup web script parameters */
|
||||||
protected Map<String, String> buildParameters()
|
protected Map<String, String> buildParameters()
|
||||||
{
|
{
|
||||||
testdoc = generateCmContent("testdoc.txt");
|
testdoc = generateCmContent("testdoc.txt");
|
||||||
|
@@ -18,6 +18,9 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.module.org_alfresco_module_rm.recorded.version.config;
|
package org.alfresco.module.org_alfresco_module_rm.recorded.version.config;
|
||||||
|
|
||||||
|
import static org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy.ALL;
|
||||||
|
import static org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy.MAJOR_ONLY;
|
||||||
|
import static org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy.NONE;
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
import static org.testng.Assert.assertEquals;
|
import static org.testng.Assert.assertEquals;
|
||||||
@@ -29,6 +32,7 @@ import java.util.List;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.alfresco.module.org_alfresco_module_rm.script.slingshot.RecordedVersionConfigGet;
|
import org.alfresco.module.org_alfresco_module_rm.script.slingshot.RecordedVersionConfigGet;
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.script.slingshot.Version;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy;
|
import org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy;
|
||||||
import org.json.JSONArray;
|
import org.json.JSONArray;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
@@ -74,7 +78,16 @@ public class RecordedVersionConfigGetTest extends BaseRecordedVersionConfigTest
|
|||||||
// Test document should not have any recordable version policy set
|
// Test document should not have any recordable version policy set
|
||||||
doReturn(null).when(mockedNodeService).getProperty(testdoc, PROP_RECORDABLE_VERSION_POLICY);
|
doReturn(null).when(mockedNodeService).getProperty(testdoc, PROP_RECORDABLE_VERSION_POLICY);
|
||||||
|
|
||||||
// execute web script
|
// Setup versions
|
||||||
|
List<Version> versions = Arrays.asList(
|
||||||
|
new Version(NONE.toString(), true),
|
||||||
|
new Version(MAJOR_ONLY.toString(), false),
|
||||||
|
new Version(ALL.toString(), false));
|
||||||
|
|
||||||
|
// Stub getVersions
|
||||||
|
doReturn(versions).when(mockedRecordableVersionConfigService).getVersions(testdoc);
|
||||||
|
|
||||||
|
// Execute web script
|
||||||
JSONObject json = executeJSONWebScript(parameters);
|
JSONObject json = executeJSONWebScript(parameters);
|
||||||
|
|
||||||
// Do checks
|
// Do checks
|
||||||
|
@@ -18,6 +18,8 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.module.org_alfresco_module_rm.recorded.version.config;
|
package org.alfresco.module.org_alfresco_module_rm.recorded.version.config;
|
||||||
|
|
||||||
|
import static org.alfresco.module.org_alfresco_module_rm.script.slingshot.RecordedVersionConfigPost.RECORDED_VERSION;
|
||||||
|
import static org.alfresco.module.org_alfresco_module_rm.version.RecordableVersionPolicy.ALL;
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
import static org.testng.Assert.assertEquals;
|
import static org.testng.Assert.assertEquals;
|
||||||
@@ -63,10 +65,8 @@ public class RecordedVersionConfigPostTest extends BaseRecordedVersionConfigTest
|
|||||||
@Test
|
@Test
|
||||||
public void setRecordedVersionConfig() throws Exception
|
public void setRecordedVersionConfig() throws Exception
|
||||||
{
|
{
|
||||||
RecordableVersionPolicy policy = RecordableVersionPolicy.ALL;
|
|
||||||
|
|
||||||
// Build the content
|
// Build the content
|
||||||
String content = buildContent(policy);
|
String content = buildContent(ALL);
|
||||||
|
|
||||||
// Build parameters
|
// Build parameters
|
||||||
Map<String, String> parameters = buildParameters();
|
Map<String, String> parameters = buildParameters();
|
||||||
@@ -82,7 +82,7 @@ public class RecordedVersionConfigPostTest extends BaseRecordedVersionConfigTest
|
|||||||
assertEquals(json.length(), 0);
|
assertEquals(json.length(), 0);
|
||||||
|
|
||||||
// Test document must have recordable version policy "ALL" set
|
// Test document must have recordable version policy "ALL" set
|
||||||
doReturn(policy).when(mockedNodeService).getProperty(testdoc, PROP_RECORDABLE_VERSION_POLICY);
|
doReturn(ALL).when(mockedNodeService).getProperty(testdoc, PROP_RECORDABLE_VERSION_POLICY);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -95,7 +95,7 @@ public class RecordedVersionConfigPostTest extends BaseRecordedVersionConfigTest
|
|||||||
{
|
{
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
sb.append("{\"");
|
sb.append("{\"");
|
||||||
sb.append(RecordedVersionConfigPost.RECORDED_VERSION);
|
sb.append(RECORDED_VERSION);
|
||||||
sb.append("\":\"");
|
sb.append("\":\"");
|
||||||
sb.append(policy.toString());
|
sb.append(policy.toString());
|
||||||
sb.append("\"}");
|
sb.append("\"}");
|
||||||
|
@@ -38,6 +38,7 @@ import org.alfresco.module.org_alfresco_module_rm.hold.HoldService;
|
|||||||
import org.alfresco.module.org_alfresco_module_rm.identifier.IdentifierService;
|
import org.alfresco.module.org_alfresco_module_rm.identifier.IdentifierService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.record.RecordService;
|
import org.alfresco.module.org_alfresco_module_rm.record.RecordService;
|
||||||
|
import org.alfresco.module.org_alfresco_module_rm.recordableversion.RecordableVersionConfigService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.recordfolder.RecordFolderService;
|
import org.alfresco.module.org_alfresco_module_rm.recordfolder.RecordFolderService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.report.ReportService;
|
import org.alfresco.module.org_alfresco_module_rm.report.ReportService;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.role.FilePlanRoleService;
|
import org.alfresco.module.org_alfresco_module_rm.role.FilePlanRoleService;
|
||||||
@@ -80,7 +81,7 @@ import org.springframework.context.ApplicationContext;
|
|||||||
* <p>
|
* <p>
|
||||||
* Contains core and records management service mocks ready for injection. Helper methods
|
* Contains core and records management service mocks ready for injection. Helper methods
|
||||||
* provide an easy way to build RM or Alfresco constructs for use in tests.
|
* provide an easy way to build RM or Alfresco constructs for use in tests.
|
||||||
*
|
*
|
||||||
* @author Roy Wetherall
|
* @author Roy Wetherall
|
||||||
* @since 2.2
|
* @since 2.2
|
||||||
*/
|
*/
|
||||||
@@ -91,21 +92,21 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
|
|
||||||
protected NodeRef recordFolder;
|
protected NodeRef recordFolder;
|
||||||
protected NodeRef record;
|
protected NodeRef record;
|
||||||
|
|
||||||
/** core service mocks */
|
/** core service mocks */
|
||||||
@Mock(name="nodeService") protected NodeService mockedNodeService;
|
@Mock(name="nodeService") protected NodeService mockedNodeService;
|
||||||
@Mock(name="dictionaryService") protected DictionaryService mockedDictionaryService;
|
@Mock(name="dictionaryService") protected DictionaryService mockedDictionaryService;
|
||||||
@Mock(name="namespaceService") protected NamespaceService mockedNamespaceService;
|
@Mock(name="namespaceService") protected NamespaceService mockedNamespaceService;
|
||||||
@Mock(name="identifierService") protected IdentifierService mockedIdentifierService;
|
@Mock(name="identifierService") protected IdentifierService mockedIdentifierService;
|
||||||
@Mock(name="permissionService") protected PermissionService mockedPermissionService;
|
@Mock(name="permissionService") protected PermissionService mockedPermissionService;
|
||||||
@Mock(name="ownableService") protected OwnableService mockedOwnableService;
|
@Mock(name="ownableService") protected OwnableService mockedOwnableService;
|
||||||
@Mock(name="searchService") protected SearchService mockedSearchService;
|
@Mock(name="searchService") protected SearchService mockedSearchService;
|
||||||
@Mock(name="retryingTransactionHelper") protected RetryingTransactionHelper mockedRetryingTransactionHelper;
|
@Mock(name="retryingTransactionHelper") protected RetryingTransactionHelper mockedRetryingTransactionHelper;
|
||||||
@Mock(name="authorityService") protected AuthorityService mockedAuthorityService;
|
@Mock(name="authorityService") protected AuthorityService mockedAuthorityService;
|
||||||
@Mock(name="policyComponent") protected PolicyComponent mockedPolicyComponent;
|
@Mock(name="policyComponent") protected PolicyComponent mockedPolicyComponent;
|
||||||
@Mock(name="copyService") protected CopyService mockedCopyService;
|
@Mock(name="copyService") protected CopyService mockedCopyService;
|
||||||
@Mock(name="fileFolderService") protected FileFolderService mockedFileFolderService;
|
@Mock(name="fileFolderService") protected FileFolderService mockedFileFolderService;
|
||||||
|
|
||||||
/** rm service mocks */
|
/** rm service mocks */
|
||||||
@Mock(name="filePlanService") protected FilePlanService mockedFilePlanService;
|
@Mock(name="filePlanService") protected FilePlanService mockedFilePlanService;
|
||||||
@Mock(name="recordFolderService") protected RecordFolderService mockedRecordFolderService;
|
@Mock(name="recordFolderService") protected RecordFolderService mockedRecordFolderService;
|
||||||
@@ -119,14 +120,15 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
@Mock(name="authenticationUtil") protected AuthenticationUtil mockedAuthenticationUtil;
|
@Mock(name="authenticationUtil") protected AuthenticationUtil mockedAuthenticationUtil;
|
||||||
@Mock(name="extendedPermissionService") protected ExtendedPermissionService mockedExtendedPermissionService;
|
@Mock(name="extendedPermissionService") protected ExtendedPermissionService mockedExtendedPermissionService;
|
||||||
@Mock(name="extendedSecurityService") protected ExtendedSecurityService mockedExtendedSecurityService;
|
@Mock(name="extendedSecurityService") protected ExtendedSecurityService mockedExtendedSecurityService;
|
||||||
|
@Mock(name="recordableVersionConfigService") protected RecordableVersionConfigService mockedRecordableVersionConfigService;
|
||||||
|
|
||||||
/** application context mock */
|
/** application context mock */
|
||||||
@Mock(name="applicationContext") protected ApplicationContext mockedApplicationContext;
|
@Mock(name="applicationContext") protected ApplicationContext mockedApplicationContext;
|
||||||
|
|
||||||
/** expected exception rule */
|
/** expected exception rule */
|
||||||
@Rule
|
@Rule
|
||||||
public ExpectedException exception = ExpectedException.none();
|
public ExpectedException exception = ExpectedException.none();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test method setup
|
* Test method setup
|
||||||
*/
|
*/
|
||||||
@@ -135,10 +137,10 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
public void before() throws Exception
|
public void before() throws Exception
|
||||||
{
|
{
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
|
||||||
// setup application context
|
// setup application context
|
||||||
doReturn(mockedNodeService).when(mockedApplicationContext).getBean("dbNodeService");
|
doReturn(mockedNodeService).when(mockedApplicationContext).getBean("dbNodeService");
|
||||||
|
|
||||||
// setup retrying transaction helper
|
// setup retrying transaction helper
|
||||||
Answer<Object> doInTransactionAnswer = new Answer<Object>()
|
Answer<Object> doInTransactionAnswer = new Answer<Object>()
|
||||||
{
|
{
|
||||||
@@ -151,36 +153,36 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
doAnswer(doInTransactionAnswer).when(mockedRetryingTransactionHelper).doInTransaction(any(RetryingTransactionCallback.class));
|
doAnswer(doInTransactionAnswer).when(mockedRetryingTransactionHelper).doInTransaction(any(RetryingTransactionCallback.class));
|
||||||
|
|
||||||
// setup mocked authentication util
|
// setup mocked authentication util
|
||||||
setupAuthenticationUtilMock();
|
setupAuthenticationUtilMock();
|
||||||
|
|
||||||
// setup file plan
|
// setup file plan
|
||||||
filePlan = generateNodeRef(TYPE_FILE_PLAN);
|
filePlan = generateNodeRef(TYPE_FILE_PLAN);
|
||||||
setupAsFilePlanComponent(filePlan);
|
setupAsFilePlanComponent(filePlan);
|
||||||
doReturn(true).when(mockedFilePlanService).isFilePlan(filePlan);
|
doReturn(true).when(mockedFilePlanService).isFilePlan(filePlan);
|
||||||
|
|
||||||
// setup basic file plan component
|
// setup basic file plan component
|
||||||
filePlanComponent = generateNodeRef();
|
filePlanComponent = generateNodeRef();
|
||||||
setupAsFilePlanComponent(filePlanComponent);
|
setupAsFilePlanComponent(filePlanComponent);
|
||||||
|
|
||||||
// setup namespace service
|
// setup namespace service
|
||||||
doReturn(RM_URI).when(mockedNamespaceService).getNamespaceURI(RM_PREFIX);
|
doReturn(RM_URI).when(mockedNamespaceService).getNamespaceURI(RM_PREFIX);
|
||||||
doReturn(CollectionUtils.unmodifiableSet(RM_PREFIX)).when(mockedNamespaceService).getPrefixes(RM_URI);
|
doReturn(CollectionUtils.unmodifiableSet(RM_PREFIX)).when(mockedNamespaceService).getPrefixes(RM_URI);
|
||||||
|
|
||||||
// setup record folder and record
|
// setup record folder and record
|
||||||
recordFolder = generateRecordFolder();
|
recordFolder = generateRecordFolder();
|
||||||
record = generateRecord();
|
record = generateRecord();
|
||||||
|
|
||||||
// set record as child of record folder
|
// set record as child of record folder
|
||||||
List<ChildAssociationRef> result = new ArrayList<ChildAssociationRef>(1);
|
List<ChildAssociationRef> result = new ArrayList<ChildAssociationRef>(1);
|
||||||
result.add(new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, recordFolder, generateQName(), record, true, 1));
|
result.add(new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, recordFolder, generateQName(), record, true, 1));
|
||||||
doReturn(result).when(mockedNodeService).getChildAssocs(eq(recordFolder), eq(ContentModel.ASSOC_CONTAINS), any(QNamePattern.class));
|
doReturn(result).when(mockedNodeService).getChildAssocs(eq(recordFolder), eq(ContentModel.ASSOC_CONTAINS), any(QNamePattern.class));
|
||||||
doReturn(result).when(mockedNodeService).getParentAssocs(record);
|
doReturn(result).when(mockedNodeService).getParentAssocs(record);
|
||||||
doReturn(Collections.singletonList(recordFolder)).when(mockedRecordFolderService).getRecordFolders(record);
|
doReturn(Collections.singletonList(recordFolder)).when(mockedRecordFolderService).getRecordFolders(record);
|
||||||
doReturn(Collections.singletonList(record)).when(mockedRecordService).getRecords(recordFolder);
|
doReturn(Collections.singletonList(record)).when(mockedRecordService).getRecords(recordFolder);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Setup authentication util mock
|
* Setup authentication util mock
|
||||||
*/
|
*/
|
||||||
@@ -197,9 +199,9 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
RunAsWork work = (RunAsWork)invocation.getArguments()[0];
|
RunAsWork work = (RunAsWork)invocation.getArguments()[0];
|
||||||
return work.doWork();
|
return work.doWork();
|
||||||
}
|
}
|
||||||
|
|
||||||
}).when(mockedAuthenticationUtil).runAsSystem(any(RunAsWork.class));
|
}).when(mockedAuthenticationUtil).runAsSystem(any(RunAsWork.class));
|
||||||
|
|
||||||
// just do the work
|
// just do the work
|
||||||
doAnswer(new Answer<Object>()
|
doAnswer(new Answer<Object>()
|
||||||
{
|
{
|
||||||
@@ -210,27 +212,27 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
RunAsWork work = (RunAsWork)invocation.getArguments()[0];
|
RunAsWork work = (RunAsWork)invocation.getArguments()[0];
|
||||||
return work.doWork();
|
return work.doWork();
|
||||||
}
|
}
|
||||||
|
|
||||||
}).when(mockedAuthenticationUtil).runAs(any(RunAsWork.class), anyString());
|
}).when(mockedAuthenticationUtil).runAs(any(RunAsWork.class), anyString());
|
||||||
|
|
||||||
// assume admin
|
// assume admin
|
||||||
doReturn("admin").when(mockedAuthenticationUtil).getAdminUserName();
|
doReturn("admin").when(mockedAuthenticationUtil).getAdminUserName();
|
||||||
doReturn("admin").when(mockedAuthenticationUtil).getFullyAuthenticatedUser();
|
doReturn("admin").when(mockedAuthenticationUtil).getFullyAuthenticatedUser();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to generate a qname.
|
* Helper method to generate a qname.
|
||||||
*
|
*
|
||||||
* @return QName qualified name
|
* @return QName qualified name
|
||||||
*/
|
*/
|
||||||
protected static QName generateQName()
|
protected static QName generateQName()
|
||||||
{
|
{
|
||||||
return QName.createQName(RM_URI, GUID.generate());
|
return QName.createQName(RM_URI, GUID.generate());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to generate hold reference
|
* Helper method to generate hold reference
|
||||||
*
|
*
|
||||||
* @param name hold name
|
* @param name hold name
|
||||||
* @return {@link NodeRef} node reference that will behave like a hold
|
* @return {@link NodeRef} node reference that will behave like a hold
|
||||||
*/
|
*/
|
||||||
@@ -241,37 +243,37 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
doReturn(true).when(mockedHoldService).isHold(hold);
|
doReturn(true).when(mockedHoldService).isHold(hold);
|
||||||
return hold;
|
return hold;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to generate record folder reference
|
* Helper method to generate record folder reference
|
||||||
*
|
*
|
||||||
* @return {@link NodeRef} node reference that will behave like a record folder
|
* @return {@link NodeRef} node reference that will behave like a record folder
|
||||||
*/
|
*/
|
||||||
protected NodeRef generateRecordFolder()
|
protected NodeRef generateRecordFolder()
|
||||||
{
|
{
|
||||||
NodeRef recordFolder = generateNodeRef(TYPE_RECORD_FOLDER);
|
NodeRef recordFolder = generateNodeRef(TYPE_RECORD_FOLDER);
|
||||||
setupAsFilePlanComponent(recordFolder);
|
setupAsFilePlanComponent(recordFolder);
|
||||||
doReturn(true).when(mockedRecordFolderService).isRecordFolder(recordFolder);
|
doReturn(true).when(mockedRecordFolderService).isRecordFolder(recordFolder);
|
||||||
return recordFolder;
|
return recordFolder;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to generate a record node reference.
|
* Helper method to generate a record node reference.
|
||||||
*
|
*
|
||||||
* @return {@link NodeRef} node reference that will behave like a record or type cm:content
|
* @return {@link NodeRef} node reference that will behave like a record or type cm:content
|
||||||
*/
|
*/
|
||||||
protected NodeRef generateRecord()
|
protected NodeRef generateRecord()
|
||||||
{
|
{
|
||||||
NodeRef record = generateNodeRef(ContentModel.TYPE_CONTENT);
|
NodeRef record = generateNodeRef(ContentModel.TYPE_CONTENT);
|
||||||
setupAsFilePlanComponent(record);
|
setupAsFilePlanComponent(record);
|
||||||
doReturn(true).when(mockedNodeService).hasAspect(record, ASPECT_RECORD);
|
doReturn(true).when(mockedNodeService).hasAspect(record, ASPECT_RECORD);
|
||||||
doReturn(true).when(mockedRecordService).isRecord(record);
|
doReturn(true).when(mockedRecordService).isRecord(record);
|
||||||
return record;
|
return record;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to setup a node reference as a file plan component.
|
* Helper method to setup a node reference as a file plan component.
|
||||||
*
|
*
|
||||||
* @param nodeRef {@link NodeRef} node reference that will now behave like a file plan component
|
* @param nodeRef {@link NodeRef} node reference that will now behave like a file plan component
|
||||||
*/
|
*/
|
||||||
protected void setupAsFilePlanComponent(NodeRef nodeRef)
|
protected void setupAsFilePlanComponent(NodeRef nodeRef)
|
||||||
@@ -284,17 +286,17 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to generate a node reference.
|
* Helper method to generate a node reference.
|
||||||
*
|
*
|
||||||
* @return {@link NodeRef} node reference that behaves like a node that exists in the spaces store
|
* @return {@link NodeRef} node reference that behaves like a node that exists in the spaces store
|
||||||
*/
|
*/
|
||||||
protected NodeRef generateNodeRef()
|
protected NodeRef generateNodeRef()
|
||||||
{
|
{
|
||||||
return generateNodeRef(null);
|
return generateNodeRef(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to generate a node reference of a particular type.
|
* Helper method to generate a node reference of a particular type.
|
||||||
*
|
*
|
||||||
* @param type content type qualified name
|
* @param type content type qualified name
|
||||||
* @return {@link NodeRef} node reference that behaves like a node that exists in the spaces store with
|
* @return {@link NodeRef} node reference that behaves like a node that exists in the spaces store with
|
||||||
* the content type provided
|
* the content type provided
|
||||||
@@ -303,10 +305,10 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
{
|
{
|
||||||
return generateNodeRef(type, true);
|
return generateNodeRef(type, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to generate a cm:content node reference with a given name.
|
* Helper method to generate a cm:content node reference with a given name.
|
||||||
*
|
*
|
||||||
* @param name content name
|
* @param name content name
|
||||||
* @return NodeRef node reference
|
* @return NodeRef node reference
|
||||||
*/
|
*/
|
||||||
@@ -316,10 +318,10 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
doReturn(name).when(mockedNodeService).getProperty(nodeRef, ContentModel.PROP_NAME);
|
doReturn(name).when(mockedNodeService).getProperty(nodeRef, ContentModel.PROP_NAME);
|
||||||
return nodeRef;
|
return nodeRef;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to generate a node reference of a particular type with a given existence characteristic.
|
* Helper method to generate a node reference of a particular type with a given existence characteristic.
|
||||||
*
|
*
|
||||||
* @param type content type qualified name
|
* @param type content type qualified name
|
||||||
* @param exists indicates whether this node should behave like a node that exists or not
|
* @param exists indicates whether this node should behave like a node that exists or not
|
||||||
* @return {@link NodeRef} node reference that behaves like a node that exists (or not) in the spaces store with
|
* @return {@link NodeRef} node reference that behaves like a node that exists (or not) in the spaces store with
|
||||||
@@ -338,7 +340,7 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to generate a mocked child association reference.
|
* Helper method to generate a mocked child association reference.
|
||||||
*
|
*
|
||||||
* @param parent parent node (optional)
|
* @param parent parent node (optional)
|
||||||
* @param child child node (optional)
|
* @param child child node (optional)
|
||||||
* @return {@link ChildAssociationRef} mocked to return the parent and child nodes
|
* @return {@link ChildAssociationRef} mocked to return the parent and child nodes
|
||||||
@@ -346,25 +348,25 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
protected ChildAssociationRef generateChildAssociationRef(NodeRef parent, NodeRef child)
|
protected ChildAssociationRef generateChildAssociationRef(NodeRef parent, NodeRef child)
|
||||||
{
|
{
|
||||||
ChildAssociationRef mockedChildAssociationRef = mock(ChildAssociationRef.class);
|
ChildAssociationRef mockedChildAssociationRef = mock(ChildAssociationRef.class);
|
||||||
|
|
||||||
if (parent != null)
|
if (parent != null)
|
||||||
{
|
{
|
||||||
doReturn(parent).when(mockedChildAssociationRef).getParentRef();
|
doReturn(parent).when(mockedChildAssociationRef).getParentRef();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (child != null)
|
if (child != null)
|
||||||
{
|
{
|
||||||
doReturn(child).when(mockedChildAssociationRef).getChildRef();
|
doReturn(child).when(mockedChildAssociationRef).getChildRef();
|
||||||
}
|
}
|
||||||
|
|
||||||
return mockedChildAssociationRef;
|
return mockedChildAssociationRef;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to make one node the primary parent of the other.
|
* Helper method to make one node the primary parent of the other.
|
||||||
* <p>
|
* <p>
|
||||||
* Assumes the cm:contains assoc type.
|
* Assumes the cm:contains assoc type.
|
||||||
*
|
*
|
||||||
* @param child
|
* @param child
|
||||||
* @param parent
|
* @param parent
|
||||||
*/
|
*/
|
||||||
@@ -374,12 +376,12 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
.when(mockedNodeService)
|
.when(mockedNodeService)
|
||||||
.getPrimaryParent(child);
|
.getPrimaryParent(child);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Helper method to make a number of nodes children of another.
|
* Helper method to make a number of nodes children of another.
|
||||||
* <p>
|
* <p>
|
||||||
* Assumes the cm:contains assoc type.
|
* Assumes the cm:contains assoc type.
|
||||||
*
|
*
|
||||||
* @param parent
|
* @param parent
|
||||||
* @param children
|
* @param children
|
||||||
*/
|
*/
|
||||||
@@ -390,10 +392,10 @@ public class BaseUnitTest implements RecordsManagementModel, ContentModel
|
|||||||
{
|
{
|
||||||
assocs.add(new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, parent, generateQName(), child));
|
assocs.add(new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, parent, generateQName(), child));
|
||||||
}
|
}
|
||||||
|
|
||||||
doReturn(assocs).when(mockedNodeService).getChildAssocs(parent, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
doReturn(assocs).when(mockedNodeService).getChildAssocs(parent, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
protected <T> List<T> buildList(T ... values)
|
protected <T> List<T> buildList(T ... values)
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user