use of org.apache.commons.lang3.time.StopWatch in project records-management by Alfresco.
the class ScheduleRecordLoadersUnitTest method testUploadRecordsWithNotExistentPreconfiguredPaths.
@Test
public void testUploadRecordsWithNotExistentPreconfiguredPaths() throws Exception {
int maxActiveLoaders = 3;
int recordsNumber = 4;
String configuredPath1 = "/e1/e2/e3";
String configuredPath2 = "/e1/e2/e4";
String paths = configuredPath1 + "," + configuredPath2;
scheduleRecordLoaders.setUploadRecords(true);
scheduleRecordLoaders.setMaxActiveLoaders(maxActiveLoaders);
scheduleRecordLoaders.setRecordsNumber(recordsNumber);
scheduleRecordLoaders.setRecordFolderPaths(paths);
// file plan should be always there
FolderData mockedFilePlanContainer = mock(FolderData.class);
when(mockedFilePlanContainer.getId()).thenReturn("filePlanId");
when(mockedFilePlanContainer.getContext()).thenReturn(FILEPLAN_CONTEXT);
when(mockedFilePlanContainer.getPath()).thenReturn(RECORD_CONTAINER_PATH);
when(mockedFileFolderService.getFolder(FILEPLAN_CONTEXT, RECORD_CONTAINER_PATH)).thenReturn(mockedFilePlanContainer);
when(mockedRestApiFactory.getFilePlansAPI()).thenReturn(mockedFilePlanAPI);
when(mockedRestApiFactory.getRecordCategoryAPI()).thenReturn(mockedRecordCategoryAPI);
FilePlan mockedFilePlan = mock(FilePlan.class);
when(mockedFilePlan.getId()).thenReturn("filePlanId");
when(mockedFilePlanAPI.getFilePlan("filePlanId")).thenReturn(mockedFilePlan);
// e1 root category
RecordCategory mockedE1FilePlanComponent = mock(RecordCategory.class);
when(mockedE1FilePlanComponent.getId()).thenReturn("e1Id");
when(mockedRecordCategoryAPI.getRecordCategory("e1Id")).thenReturn(mockedE1FilePlanComponent);
when(mockedFilePlanAPI.createRootRecordCategory(any(RecordCategory.class), eq("filePlanId"))).thenReturn(mockedE1FilePlanComponent);
String e1Path = RECORD_CONTAINER_PATH + "/e1";
FolderData mockedE1 = mock(FolderData.class);
when(mockedE1.getId()).thenReturn("e1Id");
when(mockedE1.getContext()).thenReturn(RECORD_CATEGORY_CONTEXT);
when(mockedE1.getPath()).thenReturn(e1Path);
when(mockedFileFolderService.getFolder(RECORD_CATEGORY_CONTEXT, e1Path)).thenReturn(null).thenReturn(mockedE1);
when(mockedFileFolderService.getFolder("e1Id")).thenReturn(mockedE1);
// e2 child category
RecordCategory mockedE2childRecordCategory = mock(RecordCategory.class);
when(mockedE2childRecordCategory.getId()).thenReturn("e2Id");
RecordCategoryChild mockedE2RecordCategoryChild = mock(RecordCategoryChild.class);
when(mockedE2RecordCategoryChild.getId()).thenReturn("e2Id");
when(mockedRecordCategoryAPI.getRecordCategory("e2Id")).thenReturn(mockedE2childRecordCategory);
when(mockedRecordCategoryAPI.createRecordCategoryChild(any(RecordCategoryChild.class), eq("e1Id"))).thenReturn(mockedE2RecordCategoryChild);
String e2Path = RECORD_CONTAINER_PATH + "/e1/e2";
FolderData mockedE2 = mock(FolderData.class);
when(mockedE2.getId()).thenReturn("e2Id");
when(mockedE2.getContext()).thenReturn(RECORD_CATEGORY_CONTEXT);
when(mockedE2.getPath()).thenReturn(e2Path);
when(mockedFileFolderService.getFolder(RECORD_CATEGORY_CONTEXT, e2Path)).thenReturn(null).thenReturn(mockedE2);
when(mockedFileFolderService.getFolder("e2Id")).thenReturn(mockedE2);
// e3 record folder
RecordCategoryChild mockedE3RecordFolder = mock(RecordCategoryChild.class);
when(mockedE3RecordFolder.getId()).thenReturn("e3Id");
String e3Path = RECORD_CONTAINER_PATH + "/e1/e2/e3";
FolderData mockedE3 = mock(FolderData.class);
when(mockedE3.getId()).thenReturn("e3Id");
when(mockedE3.getContext()).thenReturn(RECORD_FOLDER_CONTEXT);
when(mockedE3.getPath()).thenReturn(e3Path);
when(mockedFileFolderService.getFolder(RECORD_FOLDER_CONTEXT, e3Path)).thenReturn(null).thenReturn(null).thenReturn(mockedE3);
when(mockedFileFolderService.getFolder("e3Id")).thenReturn(mockedE3);
// e4 record folder
RecordCategoryChild mockedE4RecordFolder = mock(RecordCategoryChild.class);
when(mockedE4RecordFolder.getId()).thenReturn("e4Id");
String e4Path = RECORD_CONTAINER_PATH + "/e1/e2/e4";
FolderData mockedE4 = mock(FolderData.class);
when(mockedE4.getId()).thenReturn("e4Id");
when(mockedE4.getContext()).thenReturn(RECORD_FOLDER_CONTEXT);
when(mockedE4.getPath()).thenReturn(e4Path);
when(mockedFileFolderService.getFolder(RECORD_FOLDER_CONTEXT, e4Path)).thenReturn(null).thenReturn(null).thenReturn(mockedE4);
when(mockedFileFolderService.getFolder("e4Id")).thenReturn(mockedE4);
when(mockedRecordCategoryAPI.createRecordCategoryChild(any(RecordCategoryChild.class), eq("e2Id"))).thenReturn(mockedE3RecordFolder).thenReturn(mockedE4RecordFolder);
when(mockedApplicationContext.getBean("restAPIFactory", RestAPIFactory.class)).thenReturn(mockedRestApiFactory);
EventResult result = scheduleRecordLoaders.processEvent(null, new StopWatch());
verify(mockedFileFolderService, never()).getFoldersByCounts(any(String.class), any(Long.class), any(Long.class), any(Long.class), any(Long.class), any(Long.class), any(Long.class), any(Integer.class), any(Integer.class));
verify(mockedFileFolderService, times(4)).createNewFolder(any(String.class), any(String.class), any(String.class));
verify(mockedFileFolderService, times(4)).incrementFolderCount(any(String.class), any(String.class), eq(1L));
verify(mockedFileFolderService, times(4)).getFolder(any(String.class));
assertEquals(true, result.isSuccess());
verify(mockedSessionService, times(maxActiveLoaders)).startSession(any(DBObject.class));
assertEquals("Raised further " + (maxActiveLoaders) + " events and rescheduled self.", result.getData());
assertEquals(maxActiveLoaders + 1, result.getNextEvents().size());
for (int i = 0; i < maxActiveLoaders; i++) {
Event event = result.getNextEvents().get(i);
assertEquals(EVENT_LOAD_RECORD, event.getName());
DBObject dataObj = (DBObject) event.getData();
assertNotNull(dataObj);
assertEquals(RECORD_FOLDER_CONTEXT, (String) dataObj.get(FIELD_CONTEXT));
assertEquals(LOAD_RECORD_OPERATION, dataObj.get(FIELD_LOAD_OPERATION));
}
assertEquals(EVENT_SCHEDULE_RECORD_LOADERS, result.getNextEvents().get(maxActiveLoaders).getName());
}
use of org.apache.commons.lang3.time.StopWatch in project records-management by Alfresco.
the class ScheduleRecordLoadersUnitTest method testUploadRecordsWithExistentPathsOneCategoryAndOneRecordFolderChildOfSpecifiecCategory.
@Test
public void testUploadRecordsWithExistentPathsOneCategoryAndOneRecordFolderChildOfSpecifiecCategory() throws Exception {
int maxActiveLoaders = 8;
int recordsNumber = 4;
String configuredPath1 = "/e1/e2/e3";
String configuredPath2 = "/e1/e2/e3/e4";
String entirePath1 = RECORD_CONTAINER_PATH + configuredPath1;
String entirePath2 = RECORD_CONTAINER_PATH + configuredPath2;
String paths = configuredPath1 + "," + configuredPath2;
scheduleRecordLoaders.setUploadRecords(true);
scheduleRecordLoaders.setMaxActiveLoaders(maxActiveLoaders);
scheduleRecordLoaders.setRecordsNumber(recordsNumber);
scheduleRecordLoaders.setRecordFolderPaths(paths);
FolderData mockedRecordCategory = mock(FolderData.class);
when(mockedRecordCategory.getId()).thenReturn("recordCategoryId1");
when(mockedRecordCategory.getContext()).thenReturn(RECORD_CATEGORY_CONTEXT);
when(mockedRecordCategory.getPath()).thenReturn(entirePath1);
when(mockedFileFolderService.getFolder(RECORD_CATEGORY_CONTEXT, entirePath1)).thenReturn(mockedRecordCategory);
FolderData mockedRecordFolder1 = mock(FolderData.class);
when(mockedRecordFolder1.getId()).thenReturn("recordFolderId1");
when(mockedRecordFolder1.getContext()).thenReturn(RECORD_FOLDER_CONTEXT);
when(mockedRecordFolder1.getPath()).thenReturn(entirePath2);
when(mockedFileFolderService.getFolder(RECORD_FOLDER_CONTEXT, entirePath2)).thenReturn(mockedRecordFolder1);
when(mockedFileFolderService.getChildFolders(RECORD_CATEGORY_CONTEXT, entirePath1, 0, 100)).thenReturn(new ArrayList<FolderData>());
when(mockedFileFolderService.getChildFolders(RECORD_FOLDER_CONTEXT, entirePath1, 0, 100)).thenReturn(Arrays.asList(mockedRecordFolder1));
when(mockedFileFolderService.getChildFolders(RECORD_FOLDER_CONTEXT, entirePath1, 100, 100)).thenReturn(new ArrayList<FolderData>());
when(mockedRestApiFactory.getFilePlansAPI()).thenReturn(mockedFilePlanAPI);
when(mockedRestApiFactory.getRecordCategoryAPI()).thenReturn(mockedRecordCategoryAPI);
EventResult result = scheduleRecordLoaders.processEvent(null, new StopWatch());
verify(mockedFileFolderService, never()).getFoldersByCounts(any(String.class), any(Long.class), any(Long.class), any(Long.class), any(Long.class), any(Long.class), any(Long.class), any(Integer.class), any(Integer.class));
verify(mockedFileFolderService, times(1)).getChildFolders(eq(RECORD_CATEGORY_CONTEXT), any(String.class), any(Integer.class), any(Integer.class));
verify(mockedFileFolderService, times(2)).getChildFolders(eq(RECORD_FOLDER_CONTEXT), any(String.class), any(Integer.class), any(Integer.class));
assertEquals(true, result.isSuccess());
verify(mockedSessionService, times(recordsNumber)).startSession(any(DBObject.class));
assertEquals("Raised further " + (recordsNumber) + " events and rescheduled self.", result.getData());
assertEquals(recordsNumber + 1, result.getNextEvents().size());
for (int i = 0; i < recordsNumber; i++) {
Event event = result.getNextEvents().get(i);
assertEquals(EVENT_LOAD_RECORD, event.getName());
DBObject dataObj = (DBObject) event.getData();
assertNotNull(dataObj);
assertEquals(RECORD_FOLDER_CONTEXT, (String) dataObj.get(FIELD_CONTEXT));
assertEquals(LOAD_RECORD_OPERATION, dataObj.get(FIELD_LOAD_OPERATION));
}
assertEquals(EVENT_SCHEDULE_RECORD_LOADERS, result.getNextEvents().get(recordsNumber).getName());
}
use of org.apache.commons.lang3.time.StopWatch in project records-management by Alfresco.
the class ScheduleRecordLoadersUnitTest method testUploadRecordsWithExistentCategoryPathWithOneChildInside.
@Test
public void testUploadRecordsWithExistentCategoryPathWithOneChildInside() throws Exception {
int maxActiveLoaders = 8;
int recordsNumber = 4;
String configuredPath1 = "/e1/e2/e3";
String entirePath1 = RECORD_CONTAINER_PATH + configuredPath1;
String paths = configuredPath1;
scheduleRecordLoaders.setUploadRecords(true);
scheduleRecordLoaders.setMaxActiveLoaders(maxActiveLoaders);
scheduleRecordLoaders.setRecordsNumber(recordsNumber);
scheduleRecordLoaders.setRecordFolderPaths(paths);
FolderData mockedRecordCategory = mock(FolderData.class);
when(mockedRecordCategory.getId()).thenReturn("recordCategoryId");
when(mockedRecordCategory.getContext()).thenReturn(RECORD_CATEGORY_CONTEXT);
when(mockedRecordCategory.getPath()).thenReturn(entirePath1);
when(mockedFileFolderService.getFolder(RECORD_CATEGORY_CONTEXT, entirePath1)).thenReturn(mockedRecordCategory);
// child of configured path
String childPath = entirePath1 + "/" + "child1";
FolderData mockedRecordFolder1 = mock(FolderData.class);
when(mockedRecordFolder1.getId()).thenReturn("recordFolderId");
when(mockedRecordFolder1.getContext()).thenReturn(RECORD_FOLDER_CONTEXT);
when(mockedRecordFolder1.getPath()).thenReturn(childPath);
when(mockedFileFolderService.getFolder(RECORD_FOLDER_CONTEXT, childPath)).thenReturn(mockedRecordFolder1);
when(mockedFileFolderService.getChildFolders(RECORD_CATEGORY_CONTEXT, entirePath1, 0, 100)).thenReturn(new ArrayList<FolderData>());
when(mockedFileFolderService.getChildFolders(RECORD_FOLDER_CONTEXT, entirePath1, 0, 100)).thenReturn(Arrays.asList(mockedRecordFolder1));
when(mockedFileFolderService.getChildFolders(RECORD_FOLDER_CONTEXT, entirePath1, 100, 100)).thenReturn(new ArrayList<FolderData>());
when(mockedRestApiFactory.getFilePlansAPI()).thenReturn(mockedFilePlanAPI);
when(mockedRestApiFactory.getRecordCategoryAPI()).thenReturn(mockedRecordCategoryAPI);
EventResult result = scheduleRecordLoaders.processEvent(null, new StopWatch());
verify(mockedFileFolderService, never()).getFoldersByCounts(any(String.class), any(Long.class), any(Long.class), any(Long.class), any(Long.class), any(Long.class), any(Long.class), any(Integer.class), any(Integer.class));
verify(mockedFileFolderService, times(1)).getChildFolders(eq(RECORD_CATEGORY_CONTEXT), any(String.class), any(Integer.class), any(Integer.class));
verify(mockedFileFolderService, times(2)).getChildFolders(eq(RECORD_FOLDER_CONTEXT), any(String.class), any(Integer.class), any(Integer.class));
assertEquals(true, result.isSuccess());
verify(mockedSessionService, times(recordsNumber)).startSession(any(DBObject.class));
assertEquals("Raised further " + (recordsNumber) + " events and rescheduled self.", result.getData());
assertEquals(recordsNumber + 1, result.getNextEvents().size());
for (int i = 0; i < recordsNumber; i++) {
Event event = result.getNextEvents().get(i);
assertEquals(EVENT_LOAD_RECORD, event.getName());
DBObject dataObj = (DBObject) event.getData();
assertNotNull(dataObj);
assertEquals(RECORD_FOLDER_CONTEXT, (String) dataObj.get(FIELD_CONTEXT));
assertEquals(LOAD_RECORD_OPERATION, dataObj.get(FIELD_LOAD_OPERATION));
}
assertEquals(EVENT_SCHEDULE_RECORD_LOADERS, result.getNextEvents().get(recordsNumber).getName());
}
use of org.apache.commons.lang3.time.StopWatch in project records-management by Alfresco.
the class DeclareInPlaceRecordsUnitTest method testWithNullPassword.
@Test(expected = IllegalStateException.class)
public void testWithNullPassword() throws Exception {
String siteId = "testColabSiteId";
String username = "testUserName";
Event mockedEvent = mock(Event.class);
DBObject mockedData = mock(DBObject.class);
when(mockedData.get(FIELD_ID)).thenReturn(siteId);
when(mockedData.get(FIELD_USERNAME)).thenReturn(username);
when(mockedData.get(FIELD_PASSWORD)).thenReturn(null);
when(mockedEvent.getData()).thenReturn(mockedData);
declareInPlaceRecords.processEvent(mockedEvent, new StopWatch());
}
use of org.apache.commons.lang3.time.StopWatch in project records-management by Alfresco.
the class DeclareInPlaceRecordsUnitTest method testWithNullSiteId.
@Test(expected = IllegalStateException.class)
public void testWithNullSiteId() throws Exception {
Event mockedEvent = mock(Event.class);
DBObject mockedData = mock(DBObject.class);
when(mockedData.get(FIELD_ID)).thenReturn(null);
when(mockedEvent.getData()).thenReturn(mockedData);
declareInPlaceRecords.processEvent(mockedEvent, new StopWatch());
}
Aggregations