Skip to content

Commit

Permalink
[FIXUP] check line overlap only at confirmation
Browse files Browse the repository at this point in the history
  • Loading branch information
lmignon committed Dec 11, 2024
1 parent be10c8d commit a4bb856
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 31 deletions.
26 changes: 10 additions & 16 deletions sale_order_blanket_order/models/sale_order.py
Original file line number Diff line number Diff line change
Expand Up @@ -118,10 +118,7 @@ def init(self):
@api.constrains("order_type", "blanket_order_id", "state")
def _check_order_type(self):
for order in self:
if order.state not in ("sale", "done") and order._origin.state not in (
"sale",
"done",
):
if order.state != "sale":
continue
if order.order_type == "blanket" and order.blanket_order_id:
raise ValidationError(_("A blanket order cannot have a blanket order."))
Expand All @@ -141,10 +138,7 @@ def _check_order_type(self):
)
def _check_validity_dates(self):
for order in self:
if order.state not in ("sale", "done") and order._origin.state not in (
"sale",
"done",
):
if order.state != "sale":
continue
if order.order_type == "blanket":
if not order.blanket_validity_start_date:
Expand All @@ -168,10 +162,7 @@ def _check_validity_dates(self):
)
def _check_call_of_link_to_valid_blanket(self):
for rec in self:
if rec.state not in ("sale", "done") and rec._origin.state not in (
"sale",
"done",
):
if rec.state != "sale":
continue
if (
rec.order_type != "call_off"
Expand Down Expand Up @@ -199,10 +190,7 @@ def _check_call_of_link_to_valid_blanket(self):
@api.constrains("order_type", "blanket_order_id", "state")
def _check_blanket_order_state(self):
for order in self:
if order.state not in ("sale", "done") and order._origin.state not in (
"sale",
"done",
):
if order.state != "sale":
continue
if (
order.order_type != "call_off"
Expand Down Expand Up @@ -317,6 +305,12 @@ def _on_blanket_order_confirm(self):
raise ValidationError(

Check warning on line 305 in sale_order_blanket_order/models/sale_order.py

View check run for this annotation

Codecov / codecov/patch

sale_order_blanket_order/models/sale_order.py#L305

Added line #L305 was not covered by tests
_("Only blanket orders can be confirmed as blanket orders.")
)
# trigger validation on sale order lines for constrains
# _validate_fields We force the validation to be done here
# even if it will be done later at flush time. This is to
# ensure that the data are correct before performing any others
# operations that could use the data.
self.order_line._check_blanket_product_not_overlapping()
for order in self:
order.commitment_date = order.blanket_validity_start_date
self.blanket_need_to_be_finalized = True
Expand Down
12 changes: 11 additions & 1 deletion sale_order_blanket_order/models/sale_order_line.py
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ def init(self):
WHERE
blanket_validity_end_date IS NOT NULL
AND blanket_validity_start_date IS NOT NULL
AND blanket_validity_start_date <= blanket_validity_end_date
"""
)

Expand All @@ -104,6 +105,7 @@ def _check_call_off_order_line_price(self):
"product_id",
"product_packaging_id",
"order_partner_id",
"state",
)
def _check_blanket_product_not_overlapping(self):
"""We check that a product is not part of multiple blanket orders
Expand All @@ -128,6 +130,7 @@ def _check_blanket_product_not_overlapping(self):
"product_id",
"product_packaging_id",
"order_partner_id",
"state",
]
)
for rec in self:
Expand All @@ -136,8 +139,15 @@ def _check_blanket_product_not_overlapping(self):
order.order_type != "blanket"
or not rec.blanket_validity_start_date
or not rec.blanket_validity_end_date
or rec.state != "sale"
):
continue
if rec.blanket_validity_end_date < rec.blanket_validity_start_date:
raise ValidationError(

Check warning on line 146 in sale_order_blanket_order/models/sale_order_line.py

View check run for this annotation

Codecov / codecov/patch

sale_order_blanket_order/models/sale_order_line.py#L146

Added line #L146 was not covered by tests
_(
"The validity end date must be greater than the validity start date."
)
)
# here we use a plain SQL query to benefit of the daterange
# function available in PostgresSQL
# (http://www.postgresql.org/docs/current/static/rangetypes.html)
Expand All @@ -162,7 +172,7 @@ def _check_blanket_product_not_overlapping(self):
domain = [
("call_off_remaining_qty", ">", 0),
("order_id", "!=", order.id),
("state", "not in", ["done", "cancel"]),
("state", "not in", ["draft", "cancel"]),
("order_type", "=", "blanket"),
]
for (
Expand Down
30 changes: 16 additions & 14 deletions sale_order_blanket_order/tests/test_sale_blanket_order.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,27 +66,29 @@ def test_confirm_no_blanket_order(self):
order.action_confirm()

def test_no_product_overlap(self):
# Create a blanket order with a product that is already in the blanket order
self.blanket_so.action_confirm()
order = self.env["sale.order"].create(
{
"order_type": "blanket",
"partner_id": self.partner.id,
"blanket_validity_start_date": "2024-02-01",
"blanket_validity_end_date": "2025-01-31",
"order_line": [
Command.create(
{"product_id": self.product_1.id, "product_uom_qty": 10.0}
),
],
}
)
# Validate a blanket order with a product that is already in the blanket order
with self.assertRaisesRegex(
ValidationError,
(
"The product 'Product 1' is already part of another blanket order "
f"{self.blanket_so.name}."
),
):
self.env["sale.order"].create(
{
"order_type": "blanket",
"partner_id": self.partner.id,
"blanket_validity_start_date": "2024-02-01",
"blanket_validity_end_date": "2025-01-31",
"order_line": [
Command.create(
{"product_id": self.product_1.id, "product_uom_qty": 10.0}
),
],
}
)
order.action_confirm()

def test_reservation(self):
# Confirm the blanket order with reservation at call off
Expand Down

0 comments on commit a4bb856

Please sign in to comment.