Changed test class and commented initial fix.

This commit is contained in:
Roxana Lucanu-Ghetu
2016-06-01 17:41:36 +03:00
parent f4ac24d41f
commit e9bb18f9f5
2 changed files with 54 additions and 64 deletions

View File

@@ -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();

View File

@@ -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);
}
}