Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FINERACT-2148: Zero interest charge off, interestRecalculation = false and fix installment`s update after zero interest charge-off transaction #4237

Conversation

mariiaKraievska
Copy link
Contributor

@mariiaKraievska mariiaKraievska commented Dec 26, 2024

Description

Fix and add tests when interestRecalculation = false and zero interest charge-off behaviour. Also fix installment's update after zero interest charge-off transaction (skip zeroing interest for paid installments when interestRecalculation = false and fix last installment`s update).

Checklist

Please make sure these boxes are checked before submitting your pull request - thanks!

  • Write the commit message as per https://github.com/apache/fineract/#pull-requests

  • Acknowledge that we will not review PRs that are not passing the build ("green") - it is your responsibility to get a proposed PR to pass the build, not primarily the project's maintainers.

  • Create/update unit or integration tests for verifying the changes made.

  • Follow coding conventions at https://cwiki.apache.org/confluence/display/FINERACT/Coding+Conventions.

  • Add required Swagger annotation and update API documentation at fineract-provider/src/main/resources/static/legacy-docs/apiLive.htm with details of any API changes

  • Submission is not a "code dump". (Large changes can be made "in repository" via a branch. Ask on the developer mailing list for guidance, if required.)

FYI our guidelines for code reviews are at https://cwiki.apache.org/confluence/display/FINERACT/Code+Review+Guide.

@mariiaKraievska mariiaKraievska force-pushed the FINERACT-2148/update-instalments-interest-with-zero-after-charge-off-with-interest-recalculation-disabled branch 4 times, most recently from c407e90 to e6d305d Compare January 2, 2025 13:23
@mariiaKraievska mariiaKraievska changed the title FINERACT-2148: Zero interest charge off, interestRecalculation = false FINERACT-2148: Zero interest charge off, interestRecalculation = false and fix installment`s update after zero interest charge-off transaction Jan 2, 2025
.filter(installment -> installment.getFromDate().isAfter(transactionDate) && !installment.isObligationsMet())
.forEach(installment -> {
final BigDecimal interestPaid = MathUtil.nullToZero(installment.getInterestPaid());
final BigDecimal interestOutstanding = MathUtil.nullToZero(installment.getInterestCharged()).subtract(interestPaid);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You might wanna consider using the getInterestOutstanding method which calculates properly the outstanding amount. TLDR: alongside the paid, it can be waived or written off as well...

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done

@mariiaKraievska mariiaKraievska force-pushed the FINERACT-2148/update-instalments-interest-with-zero-after-charge-off-with-interest-recalculation-disabled branch from 9a0abcc to e8c0b3a Compare January 3, 2025 09:33
@mariiaKraievska mariiaKraievska force-pushed the FINERACT-2148/update-instalments-interest-with-zero-after-charge-off-with-interest-recalculation-disabled branch from e8c0b3a to 71aefee Compare January 3, 2025 11:51
Copy link
Contributor

@adamsaghy adamsaghy left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@adamsaghy adamsaghy merged commit dfc1d3e into apache:develop Jan 6, 2025
10 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants