From 137a0438b9a509d876b06838c5c62d237683ad0f Mon Sep 17 00:00:00 2001 From: arybakov Date: Tue, 23 Jan 2024 11:22:34 -0700 Subject: [PATCH 1/5] GRAD2-2477 (GRAD) - P3 Incident: 1950 program includes Non-Completion Reason "506 - N/A" --- .../gov/educ/api/graduation/service/GraduationService.java | 7 ++++--- .../bc/gov/educ/api/graduation/service/ReportService.java | 6 ++++-- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java index be133af9..eee950dd 100644 --- a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java +++ b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java @@ -384,13 +384,13 @@ private List processStudentList(List gradStudL gradData.setGraduationDate(gsr.getProgramCompletionDate() != null ? EducGraduationApiUtils.parsingTraxDateLocalDate(gsr.getProgramCompletionDate()) : null); gradData.setHonorsFlag(gsr.getHonoursStanding() != null && gsr.getHonoursStanding().equalsIgnoreCase("Y")); std.setGraduationData(gradData); - std.setNonGradReasons(getNonGradReasons(gsr.getNonGradReasons())); + std.setNonGradReasons(getNonGradReasons(gsr.getProgram(), gsr.getNonGradReasons())); stdPrjList.add(std); } else { std.setGraduationData(new ca.bc.gov.educ.api.graduation.model.report.GraduationData()); if (gsr.getStudentProjectedGradData() != null) { ProjectedRunClob projectedClob = (ProjectedRunClob)jsonTransformer.unmarshall(gsr.getStudentProjectedGradData(), ProjectedRunClob.class); - std.setNonGradReasons(getNonGradReasons(projectedClob.getNonGradReasons())); + std.setNonGradReasons(getNonGradReasons(gsr.getProgram(), projectedClob.getNonGradReasons())); if (!projectedClob.isGraduated()) stdPrjList.add(std); } @@ -399,7 +399,8 @@ private List processStudentList(List gradStudL return stdPrjList; } - private List getNonGradReasons(List nonGradReasons) { + private List getNonGradReasons(String gradProgramCode, List nonGradReasons) { + nonGradReasons.removeIf(a -> "506".equalsIgnoreCase(a.getTranscriptRule()) && (StringUtils.isNotBlank(gradProgramCode) && gradProgramCode.contains("1950"))); List nList = new ArrayList<>(); if (nonGradReasons != null) { for (GradRequirement gR : nonGradReasons) { diff --git a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/ReportService.java b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/ReportService.java index e8ac5eed..4fa141e1 100644 --- a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/ReportService.java +++ b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/ReportService.java @@ -278,6 +278,7 @@ private List getNonGradReasons(String gradProgramCode, List applyFilters && "505".equalsIgnoreCase(a.getTranscriptRule()) && (StringUtils.isNotBlank(gradProgramCode) && gradProgramCode.contains("1950"))); + nonGradReasons.removeIf(a -> "506".equalsIgnoreCase(a.getTranscriptRule()) && (StringUtils.isNotBlank(gradProgramCode) && gradProgramCode.contains("1950"))); for (ca.bc.gov.educ.api.graduation.model.dto.GradRequirement gR : nonGradReasons) { String code = xml ? traxReqCodes.get(gR.getRule()) : gR.getTranscriptRule(); NonGradReason obj = new NonGradReason(); @@ -1269,14 +1270,14 @@ private List getOptionalProgramAchvReport(String gradProgramCod op.setHasRequirementMet(" Check with School"); if (existingData != null && existingData.getOptionalRequirementsMet() != null) { op.setHasRequirementMet("The Following Requirements Are Met"); - op.setRequirementMet(getRequirementsMetAchvReport(existingData.getOptionalRequirementsMet(), existingData.getOptionalStudentCourses(), op.getNonGradReasons())); + op.setRequirementMet(getRequirementsMetAchvReport(gradProgramCode, existingData.getOptionalRequirementsMet(), existingData.getOptionalStudentCourses(), op.getNonGradReasons())); } opList.add(op); } return opList; } - private List getRequirementsMetAchvReport(List optionalRequirementsMet, StudentCourses optionalStudentCourses, List nonGradReasons) { + private List getRequirementsMetAchvReport(String gradProgramCode, List optionalRequirementsMet, StudentCourses optionalStudentCourses, List nonGradReasons) { List grList = new ArrayList<>(); for (ca.bc.gov.educ.api.graduation.model.dto.GradRequirement gr : optionalRequirementsMet) { if (!gr.isProjected()) { @@ -1306,6 +1307,7 @@ private List getRequirementsMetAchvReport(List "506".equalsIgnoreCase(a.getCode()) && (StringUtils.isNotBlank(gradProgramCode) && gradProgramCode.contains("1950"))); return grList; } From cecd753e2ade9ff91d9af85c69ff80544faf6d54 Mon Sep 17 00:00:00 2001 From: arybakov Date: Tue, 23 Jan 2024 11:51:51 -0700 Subject: [PATCH 2/5] GRAD2-2477 (GRAD) - P3 Incident: 1950 program includes Non-Completion Reason "506 - N/A" --- .../gov/educ/api/graduation/service/GraduationServiceTest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/test/java/ca/bc/gov/educ/api/graduation/service/GraduationServiceTest.java b/api/src/test/java/ca/bc/gov/educ/api/graduation/service/GraduationServiceTest.java index 1d475cb4..13c345a0 100644 --- a/api/src/test/java/ca/bc/gov/educ/api/graduation/service/GraduationServiceTest.java +++ b/api/src/test/java/ca/bc/gov/educ/api/graduation/service/GraduationServiceTest.java @@ -2030,7 +2030,7 @@ public void testCreateAndStoreSchoolReports() { Mockito.when(gradStatusService.getStudentListByMinCode(mincode, "accessToken")).thenReturn(sList); Mockito.when(schoolService.getSchoolDetails(mincode, "accessToken", exception)).thenReturn(sTrax); int numberOfRecord = graduationService.createAndStoreSchoolReports(uniqueList,"REGALG","accessToken"); - assertEquals(2,numberOfRecord); + assertEquals(1,numberOfRecord); } @Test From cc472faca08efac3de372810add34b1b683c90cf Mon Sep 17 00:00:00 2001 From: arybakov Date: Tue, 23 Jan 2024 15:24:20 -0700 Subject: [PATCH 3/5] GRAD2-2477 (GRAD) - P3 Incident: 1950 program includes Non-Completion Reason "506 - N/A" --- .../bc/gov/educ/api/graduation/service/GraduationService.java | 2 +- .../ca/bc/gov/educ/api/graduation/service/ReportService.java | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java index eee950dd..6abf991f 100644 --- a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java +++ b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java @@ -400,7 +400,7 @@ private List processStudentList(List gradStudL } private List getNonGradReasons(String gradProgramCode, List nonGradReasons) { - nonGradReasons.removeIf(a -> "506".equalsIgnoreCase(a.getTranscriptRule()) && (StringUtils.isNotBlank(gradProgramCode) && gradProgramCode.contains("1950"))); + nonGradReasons.removeIf(a -> ("506".equalsIgnoreCase(a.getTranscriptRule()) || "506".equalsIgnoreCase(a.getRule())) && (StringUtils.isNotBlank(gradProgramCode) && gradProgramCode.contains("1950"))); List nList = new ArrayList<>(); if (nonGradReasons != null) { for (GradRequirement gR : nonGradReasons) { diff --git a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/ReportService.java b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/ReportService.java index 4fa141e1..e38fae23 100644 --- a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/ReportService.java +++ b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/ReportService.java @@ -278,7 +278,7 @@ private List getNonGradReasons(String gradProgramCode, List applyFilters && "505".equalsIgnoreCase(a.getTranscriptRule()) && (StringUtils.isNotBlank(gradProgramCode) && gradProgramCode.contains("1950"))); - nonGradReasons.removeIf(a -> "506".equalsIgnoreCase(a.getTranscriptRule()) && (StringUtils.isNotBlank(gradProgramCode) && gradProgramCode.contains("1950"))); + nonGradReasons.removeIf(a -> ("506".equalsIgnoreCase(a.getTranscriptRule()) || "506".equalsIgnoreCase(a.getRule())) && (StringUtils.isNotBlank(gradProgramCode) && gradProgramCode.contains("1950"))); for (ca.bc.gov.educ.api.graduation.model.dto.GradRequirement gR : nonGradReasons) { String code = xml ? traxReqCodes.get(gR.getRule()) : gR.getTranscriptRule(); NonGradReason obj = new NonGradReason(); From a95cbf9bd08e647d257d67f988d44ffa747740d6 Mon Sep 17 00:00:00 2001 From: arybakov Date: Tue, 23 Jan 2024 15:37:01 -0700 Subject: [PATCH 4/5] GRAD2-2477 (GRAD) - P3 Incident: 1950 program includes Non-Completion Reason "506 - N/A" --- .../gov/educ/api/graduation/service/GraduationService.java | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java index 6abf991f..9130c090 100644 --- a/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java +++ b/api/src/main/java/ca/bc/gov/educ/api/graduation/service/GraduationService.java @@ -469,16 +469,12 @@ private byte[] getSchoolReportNonGradRegReport(ReportData data, String mincode, } + @Generated private void createAndSaveSchoolReportNonGradRegReport(ReportData data, String mincode, String accessToken) { - byte[] bytesSAR = getSchoolReportNonGradRegReport(data, mincode, accessToken); - String encodedPdf = getEncodedPdfFromBytes(bytesSAR); - SchoolReports requestObj = getSchoolReports(mincode, encodedPdf, NONGRADREG); - updateSchoolReport(accessToken, requestObj); - } private byte[] getSchoolReportStudentNonGradPrjReport(ReportData data, String mincode, String accessToken) { From d2814b1aff64eaef4a661c9d7e15e783a7bf705e Mon Sep 17 00:00:00 2001 From: Kamal Mohammed Date: Wed, 31 Jan 2024 10:01:02 -0700 Subject: [PATCH 5/5] Update pom.xml --- api/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/pom.xml b/api/pom.xml index 42e7d7a5..43bd3b3b 100644 --- a/api/pom.xml +++ b/api/pom.xml @@ -6,7 +6,7 @@ ca.bc.gov.educ educ-grad-graduation-api - 1.8.51 + 1.8.52 educ-grad-graduation-api Ministry of Education GRAD GRADUATION API