use of org.alfresco.bm.dataload.rm.services.RecordData in project records-management by Alfresco.
the class ScheduleFilingUnfiledRecordsUnitTest method testFileRecordsWithExistentPreconfiguredFilingToPaths.
@Test
public void testFileRecordsWithExistentPreconfiguredFilingToPaths() throws Exception {
int maxActiveLoaders = 8;
int recordsNumber = 4;
String recordId1 = "recordId1";
String recordId2 = "recordId2";
String recordId3 = "recordId3";
String recordId4 = "recordId4";
String configuredPath1 = "/e1/e2/e3";
String configuredPath2 = "/e1/e2/e4";
String entirePath1 = RECORD_CONTAINER_PATH + configuredPath1;
String entirePath2 = RECORD_CONTAINER_PATH + configuredPath2;
String paths = configuredPath1 + "," + configuredPath2;
scheduleFilingUnfiledRecords.setFileUnfiledRecords(true);
scheduleFilingUnfiledRecords.setMaxActiveLoaders(maxActiveLoaders);
scheduleFilingUnfiledRecords.setRecordFilingLimit("0");
scheduleFilingUnfiledRecords.setFileToRecordFolderPaths(paths);
when(mockedRecordService.getRecordCountInSpecifiedPaths(ExecutionState.UNFILED_RECORD_DECLARED.name(), null)).thenReturn(4L);
FolderData mockedRecordFolder1 = mock(FolderData.class);
when(mockedRecordFolder1.getId()).thenReturn("recordFolder1Id");
when(mockedRecordFolder1.getContext()).thenReturn(RECORD_FOLDER_CONTEXT);
when(mockedRecordFolder1.getPath()).thenReturn(entirePath1);
when(mockedFileFolderService.getFolder(RECORD_FOLDER_CONTEXT, entirePath1)).thenReturn(mockedRecordFolder1);
FolderData mockedRecordFolder2 = mock(FolderData.class);
when(mockedRecordFolder2.getId()).thenReturn("recordFolder2Id");
when(mockedRecordFolder2.getContext()).thenReturn(RECORD_FOLDER_CONTEXT);
when(mockedRecordFolder2.getPath()).thenReturn(entirePath2);
when(mockedFileFolderService.getFolder(RECORD_FOLDER_CONTEXT, entirePath2)).thenReturn(mockedRecordFolder2);
RecordData mockedRecordData1 = mock(RecordData.class);
when(mockedRecordData1.getId()).thenReturn(recordId1);
RecordData mockedRecordData2 = mock(RecordData.class);
when(mockedRecordData2.getId()).thenReturn(recordId2);
RecordData mockedRecordData3 = mock(RecordData.class);
when(mockedRecordData3.getId()).thenReturn(recordId3);
RecordData mockedRecordData4 = mock(RecordData.class);
when(mockedRecordData4.getId()).thenReturn(recordId4);
when(mockedRecordService.getRandomRecord(ExecutionState.UNFILED_RECORD_DECLARED.name(), null)).thenReturn(mockedRecordData1).thenReturn(mockedRecordData2).thenReturn(mockedRecordData3).thenReturn(mockedRecordData4);
EventResult result = scheduleFilingUnfiledRecords.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));
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());
List<String> listOfIds = Arrays.asList(recordId1, recordId2, recordId3, recordId4);
for (int i = 0; i < recordsNumber; i++) {
Event event = result.getNextEvents().get(i);
assertEquals(TEST_EVENT_FILE_UNFILED_RECORDS, event.getName());
DBObject dataObj = (DBObject) event.getData();
assertNotNull(dataObj);
assertEquals(RECORD_FOLDER_CONTEXT, (String) dataObj.get(FIELD_CONTEXT));
assertEquals(FILE_RECORD_OPERATION, dataObj.get(FIELD_LOAD_OPERATION));
assertEquals(listOfIds.get(i), dataObj.get(FIELD_RECORD_ID));
}
assertEquals(TEST_EVENT_RESCHEDULE_SELF, result.getNextEvents().get(recordsNumber).getName());
}
use of org.alfresco.bm.dataload.rm.services.RecordData in project records-management by Alfresco.
the class ScheduleFilingUnfiledRecordsUnitTest method testFileRecordsWithConfiguredInexistentFilingFromPaths.
@Test
public void testFileRecordsWithConfiguredInexistentFilingFromPaths() throws Exception {
int maxActiveLoaders = 3;
String configuredPath1 = "/e1/e2/e3";
String entirePath1 = RECORD_CONTAINER_PATH + configuredPath1;
String paths = configuredPath1;
String recordId1 = "recordId1";
String recordParentPath1 = "/recordParentPath1";
String recordParentFullPath1 = UNFILED_RECORD_CONTAINER_PATH + recordParentPath1;
String recordId2 = "recordId2";
String recordParentPath2 = "/recordParentPath2";
String recordParentFullPath2 = UNFILED_RECORD_CONTAINER_PATH + recordParentPath2;
String recordId3 = "recordId3";
String recordParentPath3 = "/recordParentPath3";
String recordParentFullPath3 = UNFILED_RECORD_CONTAINER_PATH + recordParentPath3;
String recordId4 = "recordId4";
String recordParentPath4 = "/recordParentPath4";
String recordParentFullPath4 = UNFILED_RECORD_CONTAINER_PATH + recordParentPath4;
String fileFromPathsStr = "/inexisistingPath1,/inexisistingPath2,/inexisistingPath3";
scheduleFilingUnfiledRecords.setFileUnfiledRecords(true);
scheduleFilingUnfiledRecords.setMaxActiveLoaders(maxActiveLoaders);
scheduleFilingUnfiledRecords.setRecordFilingLimit("4");
scheduleFilingUnfiledRecords.setFileToRecordFolderPaths(paths);
scheduleFilingUnfiledRecords.setFileFromUnfiledPaths(fileFromPathsStr);
FolderData mockedRecordFolder1 = mock(FolderData.class);
when(mockedRecordFolder1.getId()).thenReturn("recordFolder1Id");
when(mockedRecordFolder1.getContext()).thenReturn(RECORD_FOLDER_CONTEXT);
when(mockedRecordFolder1.getPath()).thenReturn(entirePath1);
when(mockedFileFolderService.getFolder(RECORD_FOLDER_CONTEXT, entirePath1)).thenReturn(mockedRecordFolder1);
RecordData mockedRecordData1 = mock(RecordData.class);
when(mockedRecordData1.getId()).thenReturn(recordId1);
when(mockedRecordData1.getParentPath()).thenReturn(recordParentFullPath1);
RecordData mockedRecordData2 = mock(RecordData.class);
when(mockedRecordData2.getId()).thenReturn(recordId2);
when(mockedRecordData2.getParentPath()).thenReturn(recordParentFullPath2);
RecordData mockedRecordData3 = mock(RecordData.class);
when(mockedRecordData3.getId()).thenReturn(recordId3);
when(mockedRecordData3.getParentPath()).thenReturn(recordParentFullPath3);
RecordData mockedRecordData4 = mock(RecordData.class);
when(mockedRecordData4.getId()).thenReturn(recordId4);
when(mockedRecordData4.getParentPath()).thenReturn(recordParentFullPath4);
when(mockedRecordService.getRecordsInPaths(ExecutionState.UNFILED_RECORD_DECLARED.name(), null, 0, 100)).thenReturn(Arrays.asList(mockedRecordData1, mockedRecordData2, mockedRecordData3, mockedRecordData4));
when(mockedRecordService.getRecordsInPaths(ExecutionState.UNFILED_RECORD_DECLARED.name(), null, 100, 100)).thenReturn(new ArrayList<>());
when(mockedRecordService.getRandomRecord(ExecutionState.UNFILED_RECORD_DECLARED.name(), Arrays.asList(recordParentFullPath1, recordParentFullPath2, recordParentFullPath3, recordParentFullPath4))).thenReturn(mockedRecordData1).thenReturn(mockedRecordData2).thenReturn(mockedRecordData3).thenReturn(mockedRecordData4);
EventResult result = scheduleFilingUnfiledRecords.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(mockedRecordService, times(maxActiveLoaders)).updateRecord(any(RecordData.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());
List<String> listOfIds = Arrays.asList(recordId1, recordId2, recordId3, recordId4);
for (int i = 0; i < maxActiveLoaders; i++) {
Event event = result.getNextEvents().get(i);
assertEquals(TEST_EVENT_FILE_UNFILED_RECORDS, event.getName());
DBObject dataObj = (DBObject) event.getData();
assertNotNull(dataObj);
assertEquals(RECORD_FOLDER_CONTEXT, (String) dataObj.get(FIELD_CONTEXT));
assertEquals(FILE_RECORD_OPERATION, dataObj.get(FIELD_LOAD_OPERATION));
assertEquals(listOfIds.get(i), dataObj.get(FIELD_RECORD_ID));
}
assertEquals(TEST_EVENT_RESCHEDULE_SELF, result.getNextEvents().get(maxActiveLoaders).getName());
}
use of org.alfresco.bm.dataload.rm.services.RecordData in project records-management by Alfresco.
the class RecordServiceTest method testAllowDuplicateParentPath.
@Test
public void testAllowDuplicateParentPath() {
String duplicateParentPath = "test_parentPath";
RecordData record1 = new RecordData("test_id_1", RecordContext.IN_PLACE_RECORD, "test_name_1", duplicateParentPath, "test_inPlacePath_1", ExecutionState.SCHEDULED);
recordService.createRecord(record1);
RecordData record2 = new RecordData("test_id_2", RecordContext.RECORD, "test_name_2", duplicateParentPath, "test_inPlacePath_2", ExecutionState.UNFILED_RECORD_DECLARED);
recordService.createRecord(record2);
doubleCheckOverwrittenMethods_notEqual(record1, record2);
}
use of org.alfresco.bm.dataload.rm.services.RecordData in project records-management by Alfresco.
the class RecordServiceTest method testAllowDuplicateContext.
@Test
public void testAllowDuplicateContext() {
RecordData record1 = new RecordData("test_id_1", RecordContext.IN_PLACE_RECORD, "test_name_1", "test_parentPath_1", "test_inPlacePath_1", ExecutionState.SCHEDULED);
recordService.createRecord(record1);
RecordData record2 = new RecordData("test_id_2", RecordContext.IN_PLACE_RECORD, "test_name_2", "test_parentPath_2", "test_inPlacePath_2", ExecutionState.UNFILED_RECORD_DECLARED);
recordService.createRecord(record2);
doubleCheckOverwrittenMethods_notEqual(record1, record2);
}
use of org.alfresco.bm.dataload.rm.services.RecordData in project records-management by Alfresco.
the class RecordServiceTest method testCountRecords.
@Test
public void testCountRecords() {
Random rand = new Random();
for (int j = 0; j < 50; j++) {
for (int i = 0; i < 50; i++) {
RecordData record = new RecordData("test_id(" + j + ")(" + i + ")", RecordContext.values()[rand.nextInt(2)], "test_name", "test_parentPath" + rand.nextInt(i + 1), null, ExecutionState.UNFILED_RECORD_DECLARED);
recordService.createRecord(record);
}
assertEquals((j + 1) * 50, recordService.getRecordCountInSpecifiedPaths(ExecutionState.UNFILED_RECORD_DECLARED.name(), null));
}
}
Aggregations