2
0

[FIX] account_invoice_constraint_chronology: modify past invoices

Addresses the issue as commented here:

- https://github.com/OCA/account-financial-tools/issues/1206
- https://github.com/OCA/account-financial-tools/pull/1152#issuecomment-847854629

Summary of the steps to reproduce the problem:

1. Set on the invoices journal the constraint chronology.
2. Validate an invoice for this journal today.
3. Your accountant says there's an error on an invoice from yesterday.
4. Cancel it an set it to draft. You don't even need to modify anything
5. Try to post the invoice.
6. You'll get a chronology error.

In v12 this was considered but it was lost on the migration to v13:

800c02474e/account_invoice_constraint_chronology/model/account_invoice.py (L50)

800c02474e/account_invoice_constraint_chronology/model/account_invoice.py (L70-L73)

TT34624
This commit is contained in:
david 2022-02-17 10:26:39 +01:00 committed by Zina Rasoamanana
parent b6a799ac29
commit f01806efdd
2 changed files with 19 additions and 1 deletions

View File

@ -94,7 +94,7 @@ class AccountMove(models.Model):
def write(self, vals): def write(self, vals):
if vals.get("state") != "posted": if vals.get("state") != "posted":
return super().write(vals) return super().write(vals)
previously_validated = self.filtered(lambda m: m.name and m.name != "/")
newly_posted = self.filtered(lambda move: move.state != "posted") newly_posted = self.filtered(lambda move: move.state != "posted")
res = super().write(vals) res = super().write(vals)
for move in newly_posted & self.filtered("journal_id.check_chronology"): for move in newly_posted & self.filtered("journal_id.check_chronology"):
@ -104,6 +104,8 @@ class AccountMove(models.Model):
move._raise_sequence_ordering_conflict() move._raise_sequence_ordering_conflict()
if self.search(move._get_older_conflicting_invoices_domain(), limit=1): if self.search(move._get_older_conflicting_invoices_domain(), limit=1):
move._raise_older_conflicting_invoices() move._raise_older_conflicting_invoices()
if move in previously_validated:
continue
if self.search(move._get_newer_conflicting_invoices_domain(), limit=1): if self.search(move._get_newer_conflicting_invoices_domain(), limit=1):
move._raise_newer_conflicting_invoices() move._raise_newer_conflicting_invoices()

View File

@ -133,3 +133,19 @@ class TestAccountInvoiceConstraintChronology(common.SavepointCase):
self.invoice_1.invoice_date = self.tomorrow self.invoice_1.invoice_date = self.tomorrow
with self.assertRaisesRegex(UserError, "higher number"): with self.assertRaisesRegex(UserError, "higher number"):
self.invoice_1.action_post() self.invoice_1.action_post()
def test_modify_validated_past_invoice(self):
"""We've got an invoice from yesterday that we need to modify but new ones
have been posted since. As the invoice already has a name, we should be able
to validate it"""
self.invoice_1.invoice_date = self.yesterday
self.invoice_1.action_post()
self.invoice_2.invoice_date = self.today
self.invoice_2.action_post()
self.invoice_1.button_cancel()
self.invoice_1.button_draft()
self.invoice_1.action_post()
self.invoice_1_5 = self.invoice_1.copy()
self.invoice_1_5.invoice_date = self.yesterday
with self.assertRaises(UserError):
self.invoice_1_5.action_post()