diff --git a/rm-community/rm-community-repo/test/java/org/alfresco/module/org_alfresco_module_rm/test/integration/disposition/UpdateNextDispositionActionTest.java b/rm-community/rm-community-repo/test/java/org/alfresco/module/org_alfresco_module_rm/test/integration/disposition/UpdateNextDispositionActionTest.java
new file mode 100644
index 0000000000..462198f5a7
--- /dev/null
+++ b/rm-community/rm-community-repo/test/java/org/alfresco/module/org_alfresco_module_rm/test/integration/disposition/UpdateNextDispositionActionTest.java
@@ -0,0 +1,148 @@
+/*
+ * #%L
+ * Alfresco Records Management Module
+ * %%
+ * Copyright (C) 2005 - 2016 Alfresco Software Limited
+ * %%
+ * This file is part of the Alfresco software.
+ * -
+ * If the software was purchased under a paid Alfresco license, the terms of
+ * the paid license agreement will prevail. Otherwise, the software is
+ * provided under the following open source license terms:
+ * -
+ * 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 .
+ * #L%
+ */
+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_EVENT_NAME;
+import static org.alfresco.module.org_alfresco_module_rm.test.util.CommonRMTestUtils.PERIOD_ONE_WEEK;
+import static org.alfresco.util.GUID.generate;
+
+import java.io.Serializable;
+import java.util.Collections;
+import java.util.Date;
+import java.util.HashMap;
+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.DestroyAction;
+import org.alfresco.module.org_alfresco_module_rm.action.impl.EditDispositionActionAsOfDateAction;
+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.test.util.BaseRMTestCase;
+import org.alfresco.service.cmr.repository.NodeRef;
+import org.alfresco.service.namespace.QName;
+
+/**
+* Update next disposition step integration tests.
+*
+* @author Roxana Lucanu
+* @since 2.4.1
+*/
+public class UpdateNextDispositionActionTest extends BaseRMTestCase
+{
+ /**
+ * Given a record with multiple dispositions
+ * When updating the next step
+ * Then the action is available
+ *
+ * relates to https://issues.alfresco.com/jira/browse/RM-3060
+ */
+ public void testUpdateNextDispositionAction_RM3060() throws Exception
+ {
+ doBehaviourDrivenTest(new BehaviourDrivenTest()
+ {
+ NodeRef record;
+ NodeRef folder2;
+
+ @Override
+ public void given()
+ {
+ // create category1
+ NodeRef category1 = filePlanService.createRecordCategory(filePlan, generate());
+
+ // create disposition schedule for category1
+ createDispositionSchedule(category1);
+
+ // create category2
+ NodeRef category2 = filePlanService.createRecordCategory(filePlan, generate());
+
+ // create disposition schedule for category2
+ createDispositionSchedule(category2);
+
+ // create folder2 inside category2
+ 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() throws Exception
+ {
+ // link the record to folder2
+ recordService.link(record, folder2);
+
+ // complete record
+ utils.completeRecord(record);
+
+ // set the disposition as of date to now on the record
+ rmActionService.executeRecordsManagementAction(record,
+ EditDispositionActionAsOfDateAction.NAME,
+ Collections.singletonMap(EditDispositionActionAsOfDateAction.PARAM_AS_OF_DATE, new Date()));
+
+ // cut off
+ rmActionService.executeRecordsManagementAction(record, CutOffAction.NAME, null);
+ }
+
+ @Override
+ public void then() throws Exception
+ {
+ assertTrue(nodeService.hasAspect(record, ASPECT_CUT_OFF));
+ }
+ });
+ }
+
+ 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 cutOff = new HashMap(3);
+ cutOff.put(PROP_DISPOSITION_ACTION_NAME, CutOffAction.NAME);
+ cutOff.put(PROP_DISPOSITION_DESCRIPTION, generate());
+ cutOff.put(PROP_DISPOSITION_PERIOD, PERIOD_ONE_WEEK);
+ dispositionService.addDispositionActionDefinition(ds, cutOff);
+
+ // create the properties for TRANSFER action and add it to the disposition action definition
+ Map transfer = new HashMap(3);
+ transfer.put(PROP_DISPOSITION_ACTION_NAME, TransferAction.NAME);
+ transfer.put(PROP_DISPOSITION_DESCRIPTION, generate());
+ transfer.put(PROP_DISPOSITION_EVENT, (Serializable)Collections.singletonList(DEFAULT_EVENT_NAME));
+ dispositionService.addDispositionActionDefinition(ds, transfer);
+
+ // create the properties for DESTROY action and add it to the disposition action definition
+ Map destroy = new HashMap(3);
+ destroy.put(PROP_DISPOSITION_ACTION_NAME, DestroyAction.NAME);
+ destroy.put(PROP_DISPOSITION_DESCRIPTION, generate());
+ destroy.put(PROP_DISPOSITION_PERIOD, PERIOD_ONE_WEEK);
+ dispositionService.addDispositionActionDefinition(ds, destroy);
+ }
+}
\ No newline at end of file
diff --git a/rm-server/source/java/org/alfresco/module/org_alfresco_module_rm/action/impl/EditDispositionActionAsOfDateAction.java b/rm-server/source/java/org/alfresco/module/org_alfresco_module_rm/action/impl/EditDispositionActionAsOfDateAction.java
index 59976aa365..1d4ae1aba9 100644
--- a/rm-server/source/java/org/alfresco/module/org_alfresco_module_rm/action/impl/EditDispositionActionAsOfDateAction.java
+++ b/rm-server/source/java/org/alfresco/module/org_alfresco_module_rm/action/impl/EditDispositionActionAsOfDateAction.java
@@ -38,6 +38,9 @@ public class EditDispositionActionAsOfDateAction extends RMActionExecuterAbstrac
private static final String MSG_VALID_DATE_DISP_ASOF = "rm.action.valid-date-disp-asof";
private static final String MSG_DISP_ASOF_LIFECYCLE_APPLIED = "rm.action.disp-asof-lifecycle-applied";
+ /** Action name */
+ public static final String NAME = "editDispositionActionAsOfDate";
+
/** Action parameters */
public static final String PARAM_AS_OF_DATE = "asOfDate";
diff --git a/rm-server/source/java/org/alfresco/module/org_alfresco_module_rm/disposition/DispositionServiceImpl.java b/rm-server/source/java/org/alfresco/module/org_alfresco_module_rm/disposition/DispositionServiceImpl.java
index 70f0a43957..75158f558d 100644
--- a/rm-server/source/java/org/alfresco/module/org_alfresco_module_rm/disposition/DispositionServiceImpl.java
+++ b/rm-server/source/java/org/alfresco/module/org_alfresco_module_rm/disposition/DispositionServiceImpl.java
@@ -880,6 +880,13 @@ public class DispositionServiceImpl extends ServiceBaseImpl
// Get the current action
String currentADId = (String) nodeService.getProperty(currentDispositionAction, PROP_DISPOSITION_ACTION_ID);
currentDispositionActionDefinition = di.getDispositionActionDefinition(currentADId);
+ // 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
+ if(currentDispositionActionDefinition == null)
+ {
+ String currentADName = (String) nodeService.getProperty(currentDispositionAction, PROP_DISPOSITION_ACTION);
+ currentDispositionActionDefinition = di.getDispositionActionDefinitionByName(currentADName);
+ }
// Get the next disposition action
int index = currentDispositionActionDefinition.getIndex();
diff --git a/rm-server/test/java/org/alfresco/module/org_alfresco_module_rm/test/util/CommonRMTestUtils.java b/rm-server/test/java/org/alfresco/module/org_alfresco_module_rm/test/util/CommonRMTestUtils.java
index 3d66cb81bb..c8530a1ede 100644
--- a/rm-server/test/java/org/alfresco/module/org_alfresco_module_rm/test/util/CommonRMTestUtils.java
+++ b/rm-server/test/java/org/alfresco/module/org_alfresco_module_rm/test/util/CommonRMTestUtils.java
@@ -76,6 +76,7 @@ public class CommonRMTestUtils implements RecordsManagementModel
public static final String DEFAULT_EVENT_NAME = "case_closed";
public static final String PERIOD_NONE = "none|0";
public static final String PERIOD_IMMEDIATELY = "immediately|0";
+ public static final String PERIOD_ONE_WEEK = "week|1";
/**
* Constructor