diff --git a/fineract-loan/src/main/java/org/apache/fineract/portfolio/loanaccount/domain/Loan.java b/fineract-loan/src/main/java/org/apache/fineract/portfolio/loanaccount/domain/Loan.java index aff66589ff3..a9e25e923c3 100644 --- a/fineract-loan/src/main/java/org/apache/fineract/portfolio/loanaccount/domain/Loan.java +++ b/fineract-loan/src/main/java/org/apache/fineract/portfolio/loanaccount/domain/Loan.java @@ -2012,18 +2012,10 @@ public void handleDisbursementTransaction(final LocalDate disbursedOn, final Pay updateLoanOutstandingBalances(); } - if (getApprovedOnDate() != null && DateUtils.isBefore(disbursedOn, getApprovedOnDate())) { - final String errorMessage = "The date on which a loan is disbursed cannot be before its approval date: " - + getApprovedOnDate().toString(); - throw new InvalidLoanStateTransitionException("disbursal", "cannot.be.before.approval.date", errorMessage, disbursedOn, - getApprovedOnDate()); - } - LocalDate expectedDate = getExpectedFirstRepaymentOnDate(); if (expectedDate != null && (DateUtils.isAfter(disbursedOn, this.fetchRepaymentScheduleInstallment(1).getDueDate()) || DateUtils.isAfter(disbursedOn, expectedDate)) && DateUtils.isEqual(disbursedOn, this.actualDisbursementDate)) { - final String errorMessage = "submittedOnDate cannot be after the loans expectedFirstRepaymentOnDate: " - + expectedDate.toString(); + final String errorMessage = "submittedOnDate cannot be after the loans expectedFirstRepaymentOnDate: " + expectedDate; throw new InvalidLoanStateTransitionException("disbursal", "cannot.be.after.expected.first.repayment.date", errorMessage, disbursedOn, expectedDate); } diff --git a/fineract-provider/src/main/java/org/apache/fineract/portfolio/loanaccount/serialization/LoanTransactionValidator.java b/fineract-provider/src/main/java/org/apache/fineract/portfolio/loanaccount/serialization/LoanTransactionValidator.java index feb50685519..2fc3746b48a 100644 --- a/fineract-provider/src/main/java/org/apache/fineract/portfolio/loanaccount/serialization/LoanTransactionValidator.java +++ b/fineract-provider/src/main/java/org/apache/fineract/portfolio/loanaccount/serialization/LoanTransactionValidator.java @@ -213,6 +213,12 @@ public void validateDisbursement(JsonCommand command, boolean isAccountTransfer, loan.getExpectedDisbursedOnLocalDate()); } + LocalDate approvedOnDate = loan.getApprovedOnDate(); + if (DateUtils.isBefore(actualDisbursementDate, approvedOnDate)) { + final String errorMessage = "The date on which a loan is disbursed cannot be before its approval date: " + approvedOnDate; + throw new InvalidLoanStateTransitionException("disbursal", "cannot.be.before.approval.date", errorMessage, + actualDisbursementDate, approvedOnDate); + } }); } diff --git a/integration-tests/src/test/java/org/apache/fineract/integrationtests/LoanAccountBackdatedDisbursementTest.java b/integration-tests/src/test/java/org/apache/fineract/integrationtests/LoanAccountBackdatedDisbursementTest.java index 1c5da42c252..b055d7ff691 100644 --- a/integration-tests/src/test/java/org/apache/fineract/integrationtests/LoanAccountBackdatedDisbursementTest.java +++ b/integration-tests/src/test/java/org/apache/fineract/integrationtests/LoanAccountBackdatedDisbursementTest.java @@ -860,7 +860,7 @@ public void loanAccountBackDatedDisbursementWithDisbursementDateBeforeLoanSubmit List> loanErrorData = (List>) validationErrorHelper .disburseLoanWithTransactionAmountWithError("02 March 2023", loanId, "500", CommonConstants.RESPONSE_ERROR); assertNotNull(loanErrorData); - assertEquals("Loan can't be disbursed before 2023-03-03", loanErrorData.get(0).get("defaultUserMessage")); + assertEquals("The date on which a loan is disbursed cannot be before its approval date: 2023-03-03", loanErrorData.get(0).get("defaultUserMessage")); assertEquals("error.msg.loan.actualdisbursementdate.before.submittedDate", loanErrorData.get(0).get(CommonConstants.RESPONSE_ERROR_MESSAGE_CODE));