mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-31 17:39:05 +00:00
RM-4619 - updated unit tests
This commit is contained in:
@@ -27,6 +27,7 @@
|
||||
package org.alfresco.module.org_alfresco_module_rm.model.rma.type;
|
||||
|
||||
import static org.mockito.Matchers.any;
|
||||
import static org.mockito.Matchers.eq;
|
||||
import static org.mockito.Mockito.never;
|
||||
import static org.mockito.Mockito.verify;
|
||||
import static org.mockito.Mockito.when;
|
||||
@@ -37,7 +38,7 @@ import org.alfresco.module.org_alfresco_module_rm.test.util.BaseUnitTest;
|
||||
import org.alfresco.module.org_alfresco_module_rm.test.util.TestModel;
|
||||
import org.alfresco.service.cmr.repository.ChildAssociationRef;
|
||||
import org.alfresco.service.cmr.repository.NodeRef;
|
||||
import org.alfresco.service.namespace.QName;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.mockito.InjectMocks;
|
||||
|
||||
@@ -51,6 +52,21 @@ public class RecordsManagementContainerTypeUnitTest extends BaseUnitTest
|
||||
/** test object */
|
||||
private @InjectMocks RecordsManagementContainerType recordManagementContainerType;
|
||||
|
||||
@Before
|
||||
public void before() throws Exception
|
||||
{
|
||||
super.before();
|
||||
|
||||
when(mockedDictionaryService.isSubClass(ContentModel.TYPE_FOLDER, ContentModel.TYPE_FOLDER)).thenReturn(true);
|
||||
when(mockedDictionaryService.isSubClass(ContentModel.TYPE_FOLDER, ContentModel.TYPE_SYSTEM_FOLDER)).thenReturn(false);
|
||||
|
||||
when(mockedDictionaryService.isSubClass(TestModel.NOT_RM_FOLDER_TYPE, ContentModel.TYPE_FOLDER)).thenReturn(true);
|
||||
when(mockedDictionaryService.isSubClass(TestModel.NOT_RM_FOLDER_TYPE, ContentModel.TYPE_SYSTEM_FOLDER)).thenReturn(false);
|
||||
|
||||
when(mockedDictionaryService.isSubClass(TYPE_RECORD_CATEGORY, ContentModel.TYPE_FOLDER)).thenReturn(true);
|
||||
when(mockedDictionaryService.isSubClass(TYPE_RECORD_CATEGORY, ContentModel.TYPE_SYSTEM_FOLDER)).thenReturn(false);
|
||||
}
|
||||
|
||||
/**
|
||||
* Having the Unfilled Record container and a non RM folder subtype node
|
||||
* When adding a child association between the folder and the container
|
||||
@@ -63,19 +79,90 @@ public class RecordsManagementContainerTypeUnitTest extends BaseUnitTest
|
||||
{
|
||||
/* Having a RM container and a non RM folder subtype node */
|
||||
NodeRef rmContainer = generateRMContainer();
|
||||
NodeRef rmFolder = generateNonRmFolderSubtypeNode();
|
||||
NodeRef folder = generateNonRmFolderSubtypeNode();
|
||||
|
||||
/*
|
||||
* When adding a child association between the folder and the container
|
||||
*/
|
||||
ChildAssociationRef childAssoc = new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, rmContainer, ContentModel.ASSOC_CONTAINS, rmFolder);
|
||||
ChildAssociationRef childAssoc = new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, rmContainer, ContentModel.ASSOC_CONTAINS, folder);
|
||||
recordManagementContainerType.onCreateChildAssociation(childAssoc, true);
|
||||
|
||||
/* The type should not be changed and no aspects should be added */
|
||||
verify(mockedNodeService, never()).setType(any(), any());
|
||||
verify(mockedNodeService, never()).addAspect(any(), any(), any());
|
||||
}
|
||||
|
||||
/**
|
||||
* Having the fileplan and a non RM folder node
|
||||
* When adding a child association between the fileplan and the folder
|
||||
* Then the new folder should be converted to a record category
|
||||
*/
|
||||
@Test
|
||||
public void testAddFolderInFilePlan()
|
||||
{
|
||||
NodeRef fileplan = generateNodeRef();
|
||||
when(mockedNodeService.getType(fileplan)).thenReturn(TYPE_FILE_PLAN);
|
||||
NodeRef folder = generateNonRmFolderNode();
|
||||
|
||||
ChildAssociationRef childAssoc = new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, fileplan, ContentModel.ASSOC_CONTAINS, folder);
|
||||
recordManagementContainerType.onCreateChildAssociation(childAssoc, true);
|
||||
|
||||
verify(mockedNodeService).setType(folder, TYPE_RECORD_CATEGORY);
|
||||
}
|
||||
|
||||
/**
|
||||
* Having a record category and a non RM folder node
|
||||
* When adding a child association between the record category and the folder
|
||||
* Then the new folder should be converted to a record folder
|
||||
*/
|
||||
@Test
|
||||
public void testAddFolderInRecordCategory()
|
||||
{
|
||||
NodeRef category = generateNodeRef();
|
||||
when(mockedNodeService.getType(category)).thenReturn(TYPE_RECORD_CATEGORY);
|
||||
NodeRef folder = generateNonRmFolderNode();
|
||||
|
||||
ChildAssociationRef childAssoc = new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, category, ContentModel.ASSOC_CONTAINS, folder);
|
||||
recordManagementContainerType.onCreateChildAssociation(childAssoc, true);
|
||||
|
||||
verify(mockedNodeService).setType(folder, TYPE_RECORD_FOLDER);
|
||||
}
|
||||
|
||||
/**
|
||||
* Having an unfiled record container and a non RM folder node
|
||||
* When adding a child association between the container and the folder
|
||||
* Then the new folder should be converted to a unfiled record folder
|
||||
*/
|
||||
@Test
|
||||
public void testAddFolderInUnfiledRecordContainer()
|
||||
{
|
||||
NodeRef unfiledRecordContainer = generateNodeRef();
|
||||
when(mockedNodeService.getType(unfiledRecordContainer)).thenReturn(TYPE_UNFILED_RECORD_CONTAINER);
|
||||
NodeRef folder = generateNonRmFolderNode();
|
||||
|
||||
ChildAssociationRef childAssoc = new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, unfiledRecordContainer, ContentModel.ASSOC_CONTAINS, folder);
|
||||
recordManagementContainerType.onCreateChildAssociation(childAssoc, true);
|
||||
|
||||
verify(mockedNodeService).setType(folder, TYPE_UNFILED_RECORD_FOLDER);
|
||||
}
|
||||
|
||||
/**
|
||||
* Having an unfiled record folder and a non RM folder node
|
||||
* When adding a child association between the unfiled record folder and the regular folder
|
||||
* Then the new folder should be converted to a unfiled record folder
|
||||
*/
|
||||
@Test
|
||||
public void testAddFolderInUnfiledRecordFolder()
|
||||
{
|
||||
NodeRef unfiledRecordFolder = generateNodeRef();
|
||||
when(mockedNodeService.getType(unfiledRecordFolder)).thenReturn(TYPE_UNFILED_RECORD_FOLDER);
|
||||
NodeRef folder = generateNonRmFolderNode();
|
||||
|
||||
ChildAssociationRef childAssoc = new ChildAssociationRef(ContentModel.ASSOC_CONTAINS, unfiledRecordFolder, ContentModel.ASSOC_CONTAINS, folder);
|
||||
recordManagementContainerType.onCreateChildAssociation(childAssoc, true);
|
||||
|
||||
verify(mockedNodeService).setType(folder, TYPE_UNFILED_RECORD_FOLDER);
|
||||
}
|
||||
|
||||
/**
|
||||
* Generates a record management container
|
||||
* @return reference to the generated container
|
||||
@@ -84,38 +171,33 @@ public class RecordsManagementContainerTypeUnitTest extends BaseUnitTest
|
||||
{
|
||||
NodeRef rmContainer = generateNodeRef();
|
||||
when(mockedNodeService.getType(rmContainer)).thenReturn(RecordsManagementModel.TYPE_UNFILED_RECORD_CONTAINER);
|
||||
when(mockedDictionaryService.isSubClass(RecordsManagementModel.TYPE_UNFILED_RECORD_CONTAINER, TYPE_FILE_PLAN)).thenReturn(false);
|
||||
return rmContainer;
|
||||
}
|
||||
|
||||
/**
|
||||
* Generates a folder subtype node
|
||||
* Generates a non RM folder subtype node
|
||||
* @return reference to the created folder
|
||||
*/
|
||||
private NodeRef generateNonRmFolderSubtypeNode()
|
||||
{
|
||||
NodeRef folder = generateNodeRef();
|
||||
QName folderSubtype = QName.createQName("test", "folderSubtype");
|
||||
when(mockedDictionaryService.isSubClass(folderSubtype, ContentModel.TYPE_FOLDER)).thenReturn(true);
|
||||
when(mockedDictionaryService.isSubClass(folderSubtype, ContentModel.TYPE_SYSTEM_FOLDER)).thenReturn(false);
|
||||
when(mockedNodeService.getType(folder)).thenReturn(folderSubtype);
|
||||
when(mockedNodeService.exists(folder)).thenReturn(true);
|
||||
when(mockedNodeService.hasAspect(folder, ASPECT_FILE_PLAN_COMPONENT)).thenReturn(false);
|
||||
return folder;
|
||||
NodeRef nonRmFolder = generateNodeRef();
|
||||
|
||||
when(mockedNodeService.getType(nonRmFolder)).thenReturn(TestModel.NOT_RM_FOLDER_TYPE);
|
||||
when(mockedNodeService.exists(nonRmFolder)).thenReturn(true);
|
||||
when(mockedNodeService.hasAspect(nonRmFolder, ASPECT_FILE_PLAN_COMPONENT)).thenReturn(false);
|
||||
return nonRmFolder;
|
||||
}
|
||||
|
||||
/**
|
||||
* Generates a folder node
|
||||
* Generates a non RM folder node
|
||||
* @return reference to the created folder
|
||||
*/
|
||||
private NodeRef generateNonRmFolderNode()
|
||||
{
|
||||
NodeRef nonRmFolder = generateNodeRef();
|
||||
when(mockedDictionaryService.isSubClass(TestModel.NOT_RM_FOLDER_TYPE, ContentModel.TYPE_FOLDER)).thenReturn(true);
|
||||
when(mockedNodeService.getType(nonRmFolder)).thenReturn(TestModel.NOT_RM_FOLDER_TYPE);
|
||||
when(mockedNodeService.exists(nonRmFolder)).thenReturn(true);
|
||||
when(mockedNodeService.hasAspect(nonRmFolder, ContentModel.ASPECT_HIDDEN)).thenReturn(false);
|
||||
when(mockedNodeService.hasAspect(nonRmFolder, ASPECT_FILE_PLAN_COMPONENT)).thenReturn(false);
|
||||
return nonRmFolder;
|
||||
NodeRef regularFolder = generateNodeRef();
|
||||
when(mockedNodeService.getType(regularFolder)).thenReturn(ContentModel.TYPE_FOLDER);
|
||||
when(mockedNodeService.exists(regularFolder)).thenReturn(true);
|
||||
when(mockedNodeService.hasAspect(regularFolder, ASPECT_FILE_PLAN_COMPONENT)).thenReturn(false);
|
||||
return regularFolder;
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user