From 384c006d5e549bcf6d7ee7bae5aa2e3eddf9b01c Mon Sep 17 00:00:00 2001 From: Joan Sisquella Date: Thu, 11 Apr 2024 11:59:45 +0200 Subject: [PATCH] [IMP] stock_request: Change rounding method to HALF-UP in qty_in_progress computation --- stock_request/models/stock_request.py | 11 ++++- .../models/stock_request_abstract.py | 4 +- .../models/stock_request_allocation.py | 4 +- stock_request/tests/test_stock_request.py | 42 +++++++++++++++++++ 4 files changed, 57 insertions(+), 4 deletions(-) diff --git a/stock_request/models/stock_request.py b/stock_request/models/stock_request.py index 54bbfc86..a57b60c1 100644 --- a/stock_request/models/stock_request.py +++ b/stock_request/models/stock_request.py @@ -148,9 +148,15 @@ def _compute_qty(self): done_qty = abs(other_qty - incoming_qty) open_qty = sum(request.allocation_ids.mapped("open_product_qty")) uom = request.product_id.uom_id - request.qty_done = uom._compute_quantity(done_qty, request.product_uom_id) + request.qty_done = uom._compute_quantity( + done_qty, + request.product_uom_id, + rounding_method="HALF-UP", + ) request.qty_in_progress = uom._compute_quantity( - open_qty, request.product_uom_id + open_qty, + request.product_uom_id, + rounding_method="HALF-UP", ) request.qty_cancelled = ( max( @@ -158,6 +164,7 @@ def _compute_qty(self): uom._compute_quantity( request.product_qty - done_qty - open_qty, request.product_uom_id, + rounding_method="HALF-UP", ), ) if request.allocation_ids diff --git a/stock_request/models/stock_request_abstract.py b/stock_request/models/stock_request_abstract.py index 13f163e6..55779611 100644 --- a/stock_request/models/stock_request_abstract.py +++ b/stock_request/models/stock_request_abstract.py @@ -32,7 +32,9 @@ def default_get(self, fields): def _compute_product_qty(self): for rec in self: rec.product_qty = rec.product_uom_id._compute_quantity( - rec.product_uom_qty, rec.product_id.product_tmpl_id.uom_id + rec.product_uom_qty, + rec.product_id.product_tmpl_id.uom_id, + rounding_method="HALF-UP", ) name = fields.Char(copy=False, required=True, readonly=True, default="/") diff --git a/stock_request/models/stock_request_allocation.py b/stock_request/models/stock_request_allocation.py index 1404fbe1..91762224 100644 --- a/stock_request/models/stock_request_allocation.py +++ b/stock_request/models/stock_request_allocation.py @@ -69,7 +69,9 @@ class StockRequestAllocation(models.Model): def _compute_requested_product_qty(self): for rec in self: rec.requested_product_qty = rec.product_uom_id._compute_quantity( - rec.requested_product_uom_qty, rec.product_id.uom_id + rec.requested_product_uom_qty, + rec.product_id.uom_id, + rounding_method="HALF-UP", ) @api.depends( diff --git a/stock_request/tests/test_stock_request.py b/stock_request/tests/test_stock_request.py index 9ab5d7ab..0249d38a 100644 --- a/stock_request/tests/test_stock_request.py +++ b/stock_request/tests/test_stock_request.py @@ -1341,3 +1341,45 @@ def test_stock_request_order_state_04(self): self.assertEqual(self.request_a.state, "cancel") self.assertEqual(self.request_b.state, "done") self.assertEqual(self.order.state, "done") + + def test_rounding_half_up_in_progress_01(self): + product_half_up = self._create_product( + "HALFUP", "HalfUp Product", self.main_company.id + ) + product_half_up.uom_id.rounding = 1.0 + vals = { + "product_id": product_half_up.id, + "product_uom_id": product_half_up.uom_id.id, + "product_uom_qty": 0.5, + "company_id": self.main_company.id, + "warehouse_id": self.warehouse.id, + "location_id": self.virtual_loc.id, + } + stock_request = self.stock_request.create(vals) + stock_request.action_confirm() + self.assertEqual( + stock_request.qty_in_progress, + 1, + "Quantity in progress should be the rounded up after confirmation", + ) + + def test_rounding_half_up_in_progress_02(self): + product_half_up = self._create_product( + "HALFUP", "HalfUp Product", self.main_company.id + ) + product_half_up.uom_id.rounding = 1.0 + vals = { + "product_id": product_half_up.id, + "product_uom_id": product_half_up.uom_id.id, + "product_uom_qty": 1.49, + "company_id": self.main_company.id, + "warehouse_id": self.warehouse.id, + "location_id": self.virtual_loc.id, + } + stock_request = self.stock_request.create(vals) + stock_request.action_confirm() + self.assertEqual( + stock_request.qty_in_progress, + 1, + "Quantity in progress should be the rounded down after confirmation", + )