Skip to content

Commit

Permalink
Merge pull request #450 from bcgov/feature/GRAD2-2430
Browse files Browse the repository at this point in the history
GRAD2-2430: task is complete.
  • Loading branch information
kamal-mohammed authored Dec 19, 2023
2 parents 77e0059 + df7c687 commit e525f72
Show file tree
Hide file tree
Showing 11 changed files with 153 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -146,4 +146,17 @@ public void refreshUserScheduledQueue() {

LOGGER.info(BATCH_ENDED);
}

@Scheduled(cron = "${batch.purge-old-records.cron}")
@SchedulerLock(name = "PurgeOldRecordsLock",
lockAtLeastFor = "PT1H", lockAtMostFor = "PT1H") //midnight job so lock for an hour
public void purgeOldRecords() {
LockAssert.assertLocked();
try {
this.gradDashboardService.purgeOldBatchHistoryRecords();
this.gradDashboardService.purgeOldSpringMetaDataRecords();
} catch (Exception e) {
LOGGER.error(ERROR_MSG, e.getLocalizedMessage());
}
}
}
Original file line number Diff line number Diff line change
@@ -1,13 +1,17 @@
package ca.bc.gov.educ.api.batchgraduation.repository;

import java.time.LocalDateTime;
import java.util.List;
import java.util.Optional;
import java.util.UUID;

import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;

import ca.bc.gov.educ.api.batchgraduation.entity.BatchGradAlgorithmJobHistoryEntity;
import org.springframework.transaction.annotation.Transactional;

@Repository
public interface BatchGradAlgorithmJobHistoryRepository extends JpaRepository<BatchGradAlgorithmJobHistoryEntity, UUID> {
Expand All @@ -16,4 +20,8 @@ public interface BatchGradAlgorithmJobHistoryRepository extends JpaRepository<Ba

Optional<BatchGradAlgorithmJobHistoryEntity> findByJobExecutionId(Long batchId);

@Transactional
@Modifying
@Query("delete from BatchGradAlgorithmJobHistoryEntity where createDate <= :createDate")
void deleteByCreateDateBefore(LocalDateTime createDate);
}
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,9 @@
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

import java.time.LocalDateTime;
import java.util.*;

@Repository
Expand Down Expand Up @@ -58,5 +60,10 @@ void copyAllGradAlgorithmStudents(
"and status = 'COMPLETED'\n" +
"group by graduation_program_code\n" +
"order by graduation_program_code desc", nativeQuery = true)
List<Object[]> getGraduationProgramCounts( @Param("batchId") Long batchId);
List<Object[]> getGraduationProgramCounts(@Param("batchId") Long batchId);

@Transactional
@Modifying
@Query("delete from BatchGradAlgorithmStudentEntity where createDate <= :createDate")
void deleteByCreateDateBefore(LocalDateTime createDate);
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,42 @@
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

import java.time.LocalDateTime;

@Repository
public interface BatchJobExecutionRepository extends JpaRepository<BatchJobExecutionEntity, Long> {

Page<BatchJobExecutionEntity> findAllByOrderByCreateTimeDesc(Pageable page);

@Transactional
@Modifying
@Query(value = "DELETE FROM BATCH_JOB_EXECUTION_PARAMS WHERE JOB_EXECUTION_ID IN (\n" +
"SELECT JOB_EXECUTION_ID FROM BATCH_JOB_EXECUTION WHERE CREATE_TIME <= :createDate);",
nativeQuery = true)
void deleteBatchParamsByCreateTimeBefore(LocalDateTime createDate);

@Transactional
@Modifying
@Query(value = "DELETE FROM BATCH_JOB_EXECUTION_CONTEXT WHERE JOB_EXECUTION_ID IN (\n" +
"SELECT JOB_EXECUTION_ID FROM BATCH_JOB_EXECUTION WHERE CREATE_TIME <= :createDate);",
nativeQuery = true)
void deleteBatchContextsByCreateTimeBefore(LocalDateTime createDate);

@Transactional
@Modifying
@Query(value = "DELETE FROM BATCH_JOB_INSTANCE WHERE JOB_INSTANCE_ID NOT IN (\n" +
"SELECT JOB_INSTANCE_ID FROM BATCH_JOB_EXECUTION);",
nativeQuery = true)
void deleteBatchInstancesNotInBatchJobs();

@Transactional
@Modifying
@Query(value = "DELETE FROM BATCH_JOB_EXECUTION WHERE CREATE_TIME <= :createDate;",
nativeQuery = true)
void deleteBatchJobsByCreateTimeBefore(LocalDateTime createDate);
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,33 @@

import ca.bc.gov.educ.api.batchgraduation.entity.BatchStepExecutionEntity;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

import java.time.LocalDateTime;
import java.util.List;

@Repository
public interface BatchStepExecutionRepository extends JpaRepository<BatchStepExecutionEntity, Long> {

List<BatchStepExecutionEntity> findByJobExecutionIdOrderByEndTimeDesc(Long jobExecutionId);

@Transactional
@Modifying
@Query(value = "DELETE FROM BATCH_STEP_EXECUTION_CONTEXT WHERE STEP_EXECUTION_ID IN (\n" +
"SELECT BATCH_STEP_EXECUTION.STEP_EXECUTION_ID FROM BATCH_STEP_EXECUTION WHERE JOB_EXECUTION_ID IN (\n" +
" SELECT JOB_EXECUTION_ID FROM BATCH_JOB_EXECUTION WHERE CREATE_TIME <= :createDate\n" +
"));\n",
nativeQuery = true)
void deleteBatchStepContextsByCreateTimeBefore(LocalDateTime createDate);

@Transactional
@Modifying
@Query(value = "DELETE FROM BATCH_STEP_EXECUTION WHERE JOB_EXECUTION_ID IN (\n" +
" SELECT JOB_EXECUTION_ID FROM BATCH_JOB_EXECUTION WHERE CREATE_TIME <= :createDate);",
nativeQuery = true)
void deleteBatchStepsByCreateTimeBefore(LocalDateTime createDate);

}
Original file line number Diff line number Diff line change
@@ -1,16 +1,15 @@
package ca.bc.gov.educ.api.batchgraduation.repository;

import ca.bc.gov.educ.api.batchgraduation.entity.BatchGradAlgorithmStudentEntity;
import ca.bc.gov.educ.api.batchgraduation.entity.StudentCredentialDistributionEntity;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

import java.util.Date;
import java.time.LocalDateTime;
import java.util.List;
import java.util.Optional;
import java.util.UUID;
Expand All @@ -37,4 +36,9 @@ public interface StudentCredentialDistributionRepository extends JpaRepository<S

long countAllByJobExecutionId(Long batchId);

@Transactional
@Modifying
@Query("delete from StudentCredentialDistributionEntity where createDate <= :createDate")
void deleteByCreateDateBefore(LocalDateTime createDate);

}
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import ca.bc.gov.educ.api.batchgraduation.rest.RestUtils;
import ca.bc.gov.educ.api.batchgraduation.transformer.BatchGradAlgorithmJobHistoryTransformer;
import ca.bc.gov.educ.api.batchgraduation.transformer.BatchProcessingTransformer;
import ca.bc.gov.educ.api.batchgraduation.util.EducGradBatchGraduationApiConstants;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
Expand All @@ -29,23 +30,30 @@ public class GradDashboardService extends GradService {
private final BatchStepExecutionRepository batchStepExecutionRepository;
private final BatchProcessingTransformer batchProcessingTransformer;
private final BatchProcessingRepository batchProcessingRepository;
private final StudentCredentialDistributionRepository studentCredentialDistributionRepository;
private final RestUtils restUtils;

private final EducGradBatchGraduationApiConstants constants;

public GradDashboardService(BatchGradAlgorithmJobHistoryRepository batchGradAlgorithmJobHistoryRepository,
BatchGradAlgorithmJobHistoryTransformer batchGradAlgorithmJobHistoryTransformer,
RestUtils restUtils,
BatchJobExecutionRepository batchJobExecutionRepository,
BatchStepExecutionRepository batchStepExecutionRepository,
BatchProcessingRepository batchProcessingRepository,BatchProcessingTransformer batchProcessingTransformer,
BatchGradAlgorithmStudentRepository batchGradAlgorithmStudentRepository) {
BatchGradAlgorithmStudentRepository batchGradAlgorithmStudentRepository,
StudentCredentialDistributionRepository studentCredentialDistributionRepository,
EducGradBatchGraduationApiConstants constants) {
this.batchGradAlgorithmJobHistoryRepository = batchGradAlgorithmJobHistoryRepository;
this.batchGradAlgorithmJobHistoryTransformer = batchGradAlgorithmJobHistoryTransformer;
this.batchProcessingTransformer = batchProcessingTransformer;
this.batchGradAlgorithmStudentRepository = batchGradAlgorithmStudentRepository;
this.batchJobExecutionRepository = batchJobExecutionRepository;
this.batchStepExecutionRepository = batchStepExecutionRepository;
this.batchProcessingRepository = batchProcessingRepository;
this.studentCredentialDistributionRepository = studentCredentialDistributionRepository;
this.restUtils = restUtils;
this.constants = constants;
}

@Transactional(readOnly = true)
Expand Down Expand Up @@ -198,4 +206,30 @@ private void updateBatchJobStatus(BatchGradAlgorithmJobHistory batchJobHistory,
batchGradAlgorithmJobHistoryRepository.save(entity);
batchJobHistory.setStatus(BatchStatusEnum.FAILED.toString());
}

@Transactional
public void purgeOldBatchHistoryRecords() {
final LocalDateTime createDateToCompare = this.calculateCreateDateBasedOnStaleEventInDays();
this.batchGradAlgorithmStudentRepository.deleteByCreateDateBefore(createDateToCompare);
this.studentCredentialDistributionRepository.deleteByCreateDateBefore(createDateToCompare);
this.batchGradAlgorithmJobHistoryRepository.deleteByCreateDateBefore(createDateToCompare);
}

@Transactional
public void purgeOldSpringMetaDataRecords() {
final LocalDateTime createDateToCompare = this.calculateCreateDateBasedOnStaleEventInDays();
this.batchStepExecutionRepository.deleteBatchStepContextsByCreateTimeBefore(createDateToCompare);
this.batchStepExecutionRepository.deleteBatchStepsByCreateTimeBefore(createDateToCompare);

this.batchJobExecutionRepository.deleteBatchParamsByCreateTimeBefore(createDateToCompare);
this.batchJobExecutionRepository.deleteBatchContextsByCreateTimeBefore(createDateToCompare);
this.batchJobExecutionRepository.deleteBatchJobsByCreateTimeBefore(createDateToCompare);
this.batchJobExecutionRepository.deleteBatchInstancesNotInBatchJobs();
}


private LocalDateTime calculateCreateDateBasedOnStaleEventInDays() {
final LocalDateTime currentTime = LocalDateTime.now();
return currentTime.minusDays(this.constants.getRecordsStaleInDays());
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -273,4 +273,7 @@ public class EducGradBatchGraduationApiConstants {
@Value("${splunk.log-helper.enabled}")
private boolean splunkLogHelperEnabled;

@Value("${batch.purge-old-records.staleInDays}")
private int recordsStaleInDays;

}
3 changes: 3 additions & 0 deletions api/src/main/resources/application.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,9 @@ batch:
routines:
lockAtLeastFor: ${CRON_SYSTEM_SCHEDULED_ROUTINES_LOCK_AT_LEAST_FOR}
lockAtMostFor: ${CRON_SYSTEM_SCHEDULED_ROUTINES_LOCK_AT_MOST_FOR}
purge-old-records:
cron: ${CRON_SCHEDULED_PURGE_OLD_RECORDS}
staleInDays: ${RECORDS_STALE_IN_DAYS}

#Endpoints
endpoint:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -228,4 +228,26 @@ public void testGetBatchSummary() {
assertThat(res.getBatchJobList()).hasSize(1);
}

@Test
public void testPurgeOldBatchHistoryRecords() {
boolean isExceptionThrown = false;
try {
gradDashboardService.purgeOldBatchHistoryRecords();
} catch (Exception e) {
isExceptionThrown = true;
}
assertThat(isExceptionThrown).isFalse();
}

@Test
public void testPurgeOldSpringMetaDataRecords() {
boolean isExceptionThrown = false;
try {
gradDashboardService.purgeOldSpringMetaDataRecords();
} catch (Exception e) {
isExceptionThrown = true;
}
assertThat(isExceptionThrown).isFalse();
}

}
3 changes: 3 additions & 0 deletions api/src/test/resources/application.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,9 @@ batch:
routines:
lockAtLeastFor: PT1M
lockAtMostFor: PT600M
purge-old-records:
cron: 0 30 0 * * *
staleInDays: 90

#Endpoints
endpoint:
Expand Down

0 comments on commit e525f72

Please sign in to comment.