mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-10-08 14:51:49 +00:00
Changed test class and commented initial fix.
This commit is contained in:
@@ -891,11 +891,11 @@ public class DispositionServiceImpl extends ServiceBaseImpl
|
|||||||
currentDispositionActionDefinition = di.getDispositionActionDefinition(currentADId);
|
currentDispositionActionDefinition = di.getDispositionActionDefinition(currentADId);
|
||||||
// When the record has multiple disposition schedules the current disposition action may not be found by id
|
// When the record has multiple disposition schedules the current disposition action may not be found by id
|
||||||
// In this case it will be searched by name
|
// In this case it will be searched by name
|
||||||
if(currentDispositionActionDefinition == null)
|
// if(currentDispositionActionDefinition == null)
|
||||||
{
|
// {
|
||||||
String currentADName = (String) nodeService.getProperty(currentDispositionAction, PROP_DISPOSITION_ACTION);
|
// String currentADName = (String) nodeService.getProperty(currentDispositionAction, PROP_DISPOSITION_ACTION);
|
||||||
currentDispositionActionDefinition = di.getDispositionActionDefinitionByName(currentADName);
|
// currentDispositionActionDefinition = di.getDispositionActionDefinitionByName(currentADName);
|
||||||
}
|
// }
|
||||||
|
|
||||||
// Get the next disposition action
|
// Get the next disposition action
|
||||||
int index = currentDispositionActionDefinition.getIndex();
|
int index = currentDispositionActionDefinition.getIndex();
|
||||||
|
@@ -26,25 +26,22 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.module.org_alfresco_module_rm.test.integration.disposition;
|
package org.alfresco.module.org_alfresco_module_rm.test.integration.disposition;
|
||||||
|
|
||||||
|
import static org.alfresco.module.org_alfresco_module_rm.test.util.CommonRMTestUtils.DEFAULT_DISPOSITION_DESCRIPTION;
|
||||||
import static org.alfresco.module.org_alfresco_module_rm.test.util.CommonRMTestUtils.DEFAULT_DISPOSITION_INSTRUCTIONS;
|
import static org.alfresco.module.org_alfresco_module_rm.test.util.CommonRMTestUtils.DEFAULT_DISPOSITION_INSTRUCTIONS;
|
||||||
|
import static org.alfresco.module.org_alfresco_module_rm.test.util.CommonRMTestUtils.PERIOD_IMMEDIATELY;
|
||||||
import static org.alfresco.util.GUID.generate;
|
import static org.alfresco.util.GUID.generate;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.alfresco.module.org_alfresco_module_rm.action.impl.CutOffAction;
|
import org.alfresco.module.org_alfresco_module_rm.action.impl.CutOffAction;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.action.impl.DestroyAction;
|
import org.alfresco.module.org_alfresco_module_rm.action.impl.DestroyAction;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.action.impl.TransferAction;
|
import org.alfresco.module.org_alfresco_module_rm.action.impl.TransferAction;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.disposition.DispositionSchedule;
|
import org.alfresco.module.org_alfresco_module_rm.disposition.DispositionSchedule;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.model.RecordsManagementModel;
|
|
||||||
import org.alfresco.module.org_alfresco_module_rm.test.util.BaseRMTestCase;
|
import org.alfresco.module.org_alfresco_module_rm.test.util.BaseRMTestCase;
|
||||||
import org.alfresco.module.org_alfresco_module_rm.test.util.CommonRMTestUtils;
|
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.alfresco.service.namespace.QName;
|
import org.alfresco.service.namespace.QName;
|
||||||
import org.springframework.extensions.webscripts.GUID;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update next disposition step integration tests.
|
* Update next disposition step integration tests.
|
||||||
@@ -52,10 +49,8 @@ import org.springframework.extensions.webscripts.GUID;
|
|||||||
* @author Roxana Lucanu
|
* @author Roxana Lucanu
|
||||||
* @since 2.4.1
|
* @since 2.4.1
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class UpdateNextDispositionActionTest extends BaseRMTestCase
|
public class UpdateNextDispositionActionTest extends BaseRMTestCase
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Given a record with multiple dispositions
|
* Given a record with multiple dispositions
|
||||||
* When updating the next step
|
* When updating the next step
|
||||||
@@ -68,59 +63,36 @@ public class UpdateNextDispositionActionTest extends BaseRMTestCase
|
|||||||
doBehaviourDrivenTest(new BehaviourDrivenTest()
|
doBehaviourDrivenTest(new BehaviourDrivenTest()
|
||||||
{
|
{
|
||||||
NodeRef record;
|
NodeRef record;
|
||||||
|
NodeRef folder2;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void given()
|
public void given()
|
||||||
{
|
{
|
||||||
// create first category
|
// create category1
|
||||||
NodeRef category1 = filePlanService.createRecordCategory(filePlan, generate());
|
NodeRef category1 = filePlanService.createRecordCategory(filePlan, generate());
|
||||||
|
|
||||||
// create disposition schedule for category1
|
// create disposition schedule for category1
|
||||||
DispositionSchedule ds1 = utils.createDispositionSchedule(category1, DEFAULT_DISPOSITION_INSTRUCTIONS,
|
createDispositionSchedule(category1);
|
||||||
"ds1", true, false, false);
|
|
||||||
|
|
||||||
// create the properties for CUTOFF action
|
// create category2
|
||||||
Map<QName, Serializable> adCutOff = new HashMap<QName, Serializable>(3);
|
|
||||||
adCutOff.put(RecordsManagementModel.PROP_DISPOSITION_ACTION_NAME, CutOffAction.NAME);
|
|
||||||
adCutOff.put(RecordsManagementModel.PROP_DISPOSITION_DESCRIPTION, "CutOffDesc");
|
|
||||||
adCutOff.put(RecordsManagementModel.PROP_DISPOSITION_PERIOD, CommonRMTestUtils.PERIOD_IMMEDIATELY);
|
|
||||||
|
|
||||||
dispositionService.addDispositionActionDefinition(ds1, adCutOff);
|
|
||||||
|
|
||||||
// create the properties for TRANSFER action
|
|
||||||
Map<QName, Serializable> adTransfer = new HashMap<QName, Serializable>(3);
|
|
||||||
adTransfer.put(RecordsManagementModel.PROP_DISPOSITION_ACTION_NAME, TransferAction.NAME);
|
|
||||||
adTransfer.put(RecordsManagementModel.PROP_DISPOSITION_DESCRIPTION, "TransferDesc");
|
|
||||||
List<String> eventsList = new ArrayList<String>(1);
|
|
||||||
eventsList.add("study_complete");
|
|
||||||
adTransfer.put(RecordsManagementModel.PROP_DISPOSITION_EVENT, (Serializable)eventsList);
|
|
||||||
|
|
||||||
dispositionService.addDispositionActionDefinition(ds1, adTransfer);
|
|
||||||
|
|
||||||
// create the properties for DESTROY action
|
|
||||||
Map<QName, Serializable> adDestroy = new HashMap<QName, Serializable>(3);
|
|
||||||
adDestroy.put(RecordsManagementModel.PROP_DISPOSITION_ACTION_NAME, DestroyAction.NAME);
|
|
||||||
adDestroy.put(RecordsManagementModel.PROP_DISPOSITION_DESCRIPTION, "DestroyDesc");
|
|
||||||
adDestroy.put(RecordsManagementModel.PROP_DISPOSITION_PERIOD, "week|1");
|
|
||||||
|
|
||||||
dispositionService.addDispositionActionDefinition(ds1, adDestroy);
|
|
||||||
|
|
||||||
// create folder1 > record inside category1
|
|
||||||
NodeRef firstFolder = recordFolderService.createRecordFolder(category1, GUID.generate());
|
|
||||||
record = utils.createRecord(firstFolder, GUID.generate(), "title");
|
|
||||||
|
|
||||||
// create second category
|
|
||||||
NodeRef category2 = filePlanService.createRecordCategory(filePlan, generate());
|
NodeRef category2 = filePlanService.createRecordCategory(filePlan, generate());
|
||||||
|
|
||||||
// create disposition schedule for category2
|
// create disposition schedule for category2
|
||||||
DispositionSchedule ds2 = utils.createDispositionSchedule(category2, DEFAULT_DISPOSITION_INSTRUCTIONS,
|
createDispositionSchedule(category2);
|
||||||
"ds2", true, false, true);
|
|
||||||
// add disposition actions
|
|
||||||
dispositionService.addDispositionActionDefinition(ds2, adCutOff);
|
|
||||||
dispositionService.addDispositionActionDefinition(ds2, adTransfer);
|
|
||||||
dispositionService.addDispositionActionDefinition(ds2, adDestroy);
|
|
||||||
|
|
||||||
// create folder2 inside category2
|
// create folder2 inside category2
|
||||||
NodeRef folder2 = recordFolderService.createRecordFolder(category2, GUID.generate());
|
folder2 = recordFolderService.createRecordFolder(category2, generate());
|
||||||
|
|
||||||
|
// create folder1 inside category1
|
||||||
|
NodeRef folder1 = recordFolderService.createRecordFolder(category1, generate());
|
||||||
|
|
||||||
|
// create record inside folder1
|
||||||
|
record = utils.createRecord(folder1, generate(), generate());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void when()
|
||||||
|
{
|
||||||
// link the record to folder2
|
// link the record to folder2
|
||||||
recordService.link(record, folder2);
|
recordService.link(record, folder2);
|
||||||
|
|
||||||
@@ -129,19 +101,37 @@ public class UpdateNextDispositionActionTest extends BaseRMTestCase
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void when()
|
public void then() throws Exception
|
||||||
{
|
{
|
||||||
// complete event
|
// cut off
|
||||||
rmActionService.executeRecordsManagementAction(record, CutOffAction.NAME, null);
|
rmActionService.executeRecordsManagementAction(record, CutOffAction.NAME, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void then()
|
|
||||||
{
|
|
||||||
// ensure the record folder is cut off
|
|
||||||
assertTrue(dispositionService.isDisposableItemCutoff(record));
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
private void createDispositionSchedule(NodeRef category)
|
||||||
|
{
|
||||||
|
DispositionSchedule ds = utils.createDispositionSchedule(category, DEFAULT_DISPOSITION_INSTRUCTIONS, DEFAULT_DISPOSITION_DESCRIPTION, true, false, false);
|
||||||
|
|
||||||
|
// create the properties for CUTOFF action and add it to the disposition action definition
|
||||||
|
Map<QName, Serializable> cutOff = new HashMap<QName, Serializable>(3);
|
||||||
|
cutOff.put(PROP_DISPOSITION_ACTION_NAME, CutOffAction.NAME);
|
||||||
|
cutOff.put(PROP_DISPOSITION_DESCRIPTION, generate());
|
||||||
|
cutOff.put(PROP_DISPOSITION_PERIOD, PERIOD_IMMEDIATELY);
|
||||||
|
dispositionService.addDispositionActionDefinition(ds, cutOff);
|
||||||
|
|
||||||
|
// create the properties for TRANSFER action and add it to the disposition action definition
|
||||||
|
Map<QName, Serializable> transfer = new HashMap<QName, Serializable>(3);
|
||||||
|
transfer.put(PROP_DISPOSITION_ACTION_NAME, TransferAction.NAME);
|
||||||
|
transfer.put(PROP_DISPOSITION_DESCRIPTION, generate());
|
||||||
|
transfer.put(PROP_DISPOSITION_PERIOD, PERIOD_IMMEDIATELY);
|
||||||
|
dispositionService.addDispositionActionDefinition(ds, transfer);
|
||||||
|
|
||||||
|
// create the properties for DESTROY action and add it to the disposition action definition
|
||||||
|
Map<QName, Serializable> destroy = new HashMap<QName, Serializable>(3);
|
||||||
|
destroy.put(PROP_DISPOSITION_ACTION_NAME, DestroyAction.NAME);
|
||||||
|
destroy.put(PROP_DISPOSITION_DESCRIPTION, generate());
|
||||||
|
destroy.put(PROP_DISPOSITION_PERIOD, PERIOD_IMMEDIATELY);
|
||||||
|
dispositionService.addDispositionActionDefinition(ds, destroy);
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user