mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
RM-1661 (Performance on setting permissions at a high category level)
* Fixed failing unit tests git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/modules/recordsmanagement/BRANCHES/V2.1.0.x@88193 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -40,44 +40,44 @@ import org.alfresco.util.GUID;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* System test for RM-1008
|
* System test for RM-1008
|
||||||
*
|
*
|
||||||
* @author Roy Wetherall
|
* @author Roy Wetherall
|
||||||
* @since 2.1
|
* @since 2.1
|
||||||
*/
|
*/
|
||||||
public class RM1008Test extends BaseRMTestCase
|
public class RM1008Test extends BaseRMTestCase
|
||||||
{
|
{
|
||||||
private String myUser;
|
private String myUser;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void initServices()
|
protected void initServices()
|
||||||
{
|
{
|
||||||
super.initServices();
|
super.initServices();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean isRecordTest()
|
protected boolean isRecordTest()
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean isUserTest()
|
protected boolean isUserTest()
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void setupTestUsersImpl(NodeRef filePlan)
|
protected void setupTestUsersImpl(NodeRef filePlan)
|
||||||
{
|
{
|
||||||
super.setupTestUsersImpl(filePlan);
|
super.setupTestUsersImpl(filePlan);
|
||||||
|
|
||||||
myUser = GUID.generate();
|
myUser = GUID.generate();
|
||||||
createPerson(myUser);
|
createPerson(myUser);
|
||||||
filePlanRoleService.assignRoleToAuthority(filePlan, FilePlanRoleService.ROLE_USER, myUser);
|
filePlanRoleService.assignRoleToAuthority(filePlan, FilePlanRoleService.ROLE_USER, myUser);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testContainers() throws Exception
|
public void testContainers() throws Exception
|
||||||
{
|
{
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
@@ -87,20 +87,20 @@ public class RM1008Test extends BaseRMTestCase
|
|||||||
assertNotNull(holdContainer);
|
assertNotNull(holdContainer);
|
||||||
NodeRef transferContainer = filePlanService.getTransferContainer(filePlan);
|
NodeRef transferContainer = filePlanService.getTransferContainer(filePlan);
|
||||||
assertNotNull(transferContainer);
|
assertNotNull(transferContainer);
|
||||||
|
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(holdContainer));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(holdContainer));
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transferContainer));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transferContainer));
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(holdContainer, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(holdContainer, RMPermissionModel.FILING));
|
||||||
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(transferContainer, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(transferContainer, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, rmAdminName);
|
}, rmAdminName);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
@@ -110,23 +110,23 @@ public class RM1008Test extends BaseRMTestCase
|
|||||||
assertNotNull(holdContainer);
|
assertNotNull(holdContainer);
|
||||||
NodeRef transferContainer = filePlanService.getTransferContainer(filePlan);
|
NodeRef transferContainer = filePlanService.getTransferContainer(filePlan);
|
||||||
assertNotNull(transferContainer);
|
assertNotNull(transferContainer);
|
||||||
|
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(holdContainer));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(holdContainer));
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transferContainer));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transferContainer));
|
||||||
|
|
||||||
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(holdContainer, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(holdContainer, RMPermissionModel.FILING));
|
||||||
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(transferContainer, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(transferContainer, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, myUser);
|
}, myUser);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testHold()
|
public void testHold()
|
||||||
{
|
{
|
||||||
final NodeRef hold = doTestInTransaction(new Test<NodeRef>()
|
final NodeRef hold = doTestInTransaction(new Test<NodeRef>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
@@ -138,7 +138,7 @@ public class RM1008Test extends BaseRMTestCase
|
|||||||
return holds.iterator().next();
|
return holds.iterator().next();
|
||||||
}
|
}
|
||||||
}, rmAdminName);
|
}, rmAdminName);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
@@ -146,82 +146,83 @@ public class RM1008Test extends BaseRMTestCase
|
|||||||
{
|
{
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(hold));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(hold));
|
||||||
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(hold, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(hold, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, rmAdminName);
|
}, rmAdminName);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(hold));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(hold));
|
||||||
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(hold, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(hold, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, myUser);
|
}, myUser);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
filePlanPermissionService.setPermission(filePlan, myUser, FILING);
|
filePlanPermissionService.setPermission(filePlan, myUser, FILING);
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, rmAdminName);
|
}, rmAdminName);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(hold));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(hold));
|
||||||
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(hold, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(hold, RMPermissionModel.READ_RECORDS));
|
||||||
|
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(hold, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, myUser);
|
}, myUser);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
filePlanPermissionService.deletePermission(filePlan, myUser, FILING);
|
filePlanPermissionService.deletePermission(filePlan, myUser, FILING);
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, rmAdminName);
|
}, rmAdminName);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(hold));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(hold));
|
||||||
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(hold, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(hold, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, myUser);
|
}, myUser);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testTransfer()
|
public void testTransfer()
|
||||||
{
|
{
|
||||||
final NodeRef transferFolder = doTestInTransaction(new Test<NodeRef>()
|
final NodeRef transferFolder = doTestInTransaction(new Test<NodeRef>()
|
||||||
@@ -235,39 +236,39 @@ public class RM1008Test extends BaseRMTestCase
|
|||||||
dsProps.put(PROP_DISPOSITION_AUTHORITY, "test");
|
dsProps.put(PROP_DISPOSITION_AUTHORITY, "test");
|
||||||
dsProps.put(PROP_DISPOSITION_INSTRUCTIONS, "test");
|
dsProps.put(PROP_DISPOSITION_INSTRUCTIONS, "test");
|
||||||
dsProps.put(PROP_RECORD_LEVEL_DISPOSITION, false);
|
dsProps.put(PROP_RECORD_LEVEL_DISPOSITION, false);
|
||||||
DispositionSchedule dispositionSchedule = dispositionService.createDispositionSchedule(transferCat, dsProps);
|
DispositionSchedule dispositionSchedule = dispositionService.createDispositionSchedule(transferCat, dsProps);
|
||||||
|
|
||||||
Map<QName, Serializable> adParams = new HashMap<QName, Serializable>(3);
|
Map<QName, Serializable> adParams = new HashMap<QName, Serializable>(3);
|
||||||
adParams.put(PROP_DISPOSITION_ACTION_NAME, "cutoff");
|
adParams.put(PROP_DISPOSITION_ACTION_NAME, "cutoff");
|
||||||
adParams.put(PROP_DISPOSITION_DESCRIPTION, "test");
|
adParams.put(PROP_DISPOSITION_DESCRIPTION, "test");
|
||||||
adParams.put(PROP_DISPOSITION_PERIOD, "immediately|0");
|
adParams.put(PROP_DISPOSITION_PERIOD, "immediately|0");
|
||||||
|
|
||||||
dispositionService.addDispositionActionDefinition(dispositionSchedule, adParams);
|
dispositionService.addDispositionActionDefinition(dispositionSchedule, adParams);
|
||||||
|
|
||||||
adParams = new HashMap<QName, Serializable>(3);
|
adParams = new HashMap<QName, Serializable>(3);
|
||||||
adParams.put(PROP_DISPOSITION_ACTION_NAME, "transfer");
|
adParams.put(PROP_DISPOSITION_ACTION_NAME, "transfer");
|
||||||
adParams.put(PROP_DISPOSITION_DESCRIPTION, "test");
|
adParams.put(PROP_DISPOSITION_DESCRIPTION, "test");
|
||||||
adParams.put(PROP_DISPOSITION_PERIOD, "immediately|0");
|
adParams.put(PROP_DISPOSITION_PERIOD, "immediately|0");
|
||||||
|
|
||||||
dispositionService.addDispositionActionDefinition(dispositionSchedule, adParams);
|
dispositionService.addDispositionActionDefinition(dispositionSchedule, adParams);
|
||||||
|
|
||||||
return rmService.createRecordFolder(transferCat, "transferFolder");
|
return rmService.createRecordFolder(transferCat, "transferFolder");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
final NodeRef transfer = doTestInTransaction(new Test<NodeRef>()
|
final NodeRef transfer = doTestInTransaction(new Test<NodeRef>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public NodeRef run()
|
public NodeRef run()
|
||||||
{
|
{
|
||||||
actionService.executeRecordsManagementAction(transferFolder, "cutoff");
|
actionService.executeRecordsManagementAction(transferFolder, "cutoff");
|
||||||
actionService.executeRecordsManagementAction(transferFolder, "transfer");
|
actionService.executeRecordsManagementAction(transferFolder, "transfer");
|
||||||
|
|
||||||
NodeRef transferContainer = filePlanService.getTransferContainer(filePlan);
|
NodeRef transferContainer = filePlanService.getTransferContainer(filePlan);
|
||||||
List<ChildAssociationRef> childAssocs = nodeService.getChildAssocs(transferContainer, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
List<ChildAssociationRef> childAssocs = nodeService.getChildAssocs(transferContainer, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||||
return childAssocs.get(0).getChildRef();
|
return childAssocs.get(0).getChildRef();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void test(NodeRef result) throws Exception
|
public void test(NodeRef result) throws Exception
|
||||||
{
|
{
|
||||||
@@ -275,7 +276,7 @@ public class RM1008Test extends BaseRMTestCase
|
|||||||
assertEquals(TYPE_TRANSFER, nodeService.getType(result));
|
assertEquals(TYPE_TRANSFER, nodeService.getType(result));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
@@ -283,82 +284,83 @@ public class RM1008Test extends BaseRMTestCase
|
|||||||
{
|
{
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transfer));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transfer));
|
||||||
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(transfer, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(transfer, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, rmAdminName);
|
}, rmAdminName);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transfer));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transfer));
|
||||||
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(transfer, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(transfer, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, myUser);
|
}, myUser);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
filePlanPermissionService.setPermission(filePlan, myUser, FILING);
|
filePlanPermissionService.setPermission(filePlan, myUser, FILING);
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, rmAdminName);
|
}, rmAdminName);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transfer));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transfer));
|
||||||
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(transfer, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.ALLOWED, permissionService.hasPermission(transfer, RMPermissionModel.READ_RECORDS));
|
||||||
|
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(transfer, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, myUser);
|
}, myUser);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
filePlanPermissionService.deletePermission(filePlan, myUser, FILING);
|
filePlanPermissionService.deletePermission(filePlan, myUser, FILING);
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, rmAdminName);
|
}, rmAdminName);
|
||||||
|
|
||||||
doTestInTransaction(new Test<Void>()
|
doTestInTransaction(new Test<Void>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public Void run()
|
public Void run()
|
||||||
{
|
{
|
||||||
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
Capability viewRecords = capabilityService.getCapability("ViewRecords");
|
||||||
assertNotNull(viewRecords);
|
assertNotNull(viewRecords);
|
||||||
|
|
||||||
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transfer));
|
assertEquals(AccessStatus.ALLOWED, viewRecords.hasPermission(transfer));
|
||||||
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(transfer, RMPermissionModel.FILING));
|
assertEquals(AccessStatus.DENIED, permissionService.hasPermission(transfer, RMPermissionModel.FILING));
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}, myUser);
|
}, myUser);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user