From 66ac7694357f1d624b30753f836c859bf4c6b33d Mon Sep 17 00:00:00 2001 From: Thierry Ducrest Date: Mon, 17 Jul 2023 14:04:16 +0200 Subject: [PATCH 1/2] Fix stock_location_package_restriction for backorder Only check the restriction for moves actually being done. --- .../models/stock_move.py | 3 +- .../tests/test_stock_move.py | 43 +++++++++++++++++++ 2 files changed, 45 insertions(+), 1 deletion(-) diff --git a/stock_location_package_restriction/models/stock_move.py b/stock_location_package_restriction/models/stock_move.py index e626df6095f8..9f999ee4be3a 100644 --- a/stock_location_package_restriction/models/stock_move.py +++ b/stock_location_package_restriction/models/stock_move.py @@ -31,8 +31,9 @@ def _check_location_package_restriction(self): location_packages = { g["location_id"][0]: set(g["package_id"]) for g in quants_grouped } + lines_being_processed = self.move_line_ids.filtered(lambda line: line.qty_done) for location, move_lines in groupby( - self.move_line_ids, lambda m: m.location_dest_id + lines_being_processed, lambda m: m.location_dest_id ): if not location.package_restriction: continue diff --git a/stock_location_package_restriction/tests/test_stock_move.py b/stock_location_package_restriction/tests/test_stock_move.py index 06205eacc8d4..695de10b8e43 100644 --- a/stock_location_package_restriction/tests/test_stock_move.py +++ b/stock_location_package_restriction/tests/test_stock_move.py @@ -246,6 +246,49 @@ def test_03(self): with self.assertRaises(ValidationError): self._process_picking(picking) + def test_03_with_backorder(self): + """ + Data: + location_2 without package but with package restriction = 'single package' + a picking with two move with destination location_2 but only one move is + being processsed, backorder creation. + Test case: + Process the picking + Expected result: + One package in location no error + """ + self.location_2.package_restriction = SINGLEPACKAGE + picking = self._create_and_assign_picking( + [ + ShortMoveInfo( + product=self.product_1, + location_dest=self.location_2, + qty=2, + package_id=self.pack_1, + ), + ShortMoveInfo( + product=self.product_2, + location_dest=self.location_2, + qty=2, + package_id=self.pack_2, + ), + ], + location_dest=self.location_2, + ) + picking.action_assign() + # Processing only one move out of two + line_to_process = picking.move_line_ids[0] + line_to_process.qty_done = line_to_process.product_qty + wizard_action = picking.button_validate() + wizard_context = wizard_action.get("context", {}) + wizard = ( + self.env[wizard_action["res_model"]] + .with_context(**wizard_context) + .create({}) + ) + wizard.process() + self.assertEqual(self.pack_1, self._get_package_in_location(self.location_2)) + def test_04(self): """ Data: From de01825952ac770197a168d8186c5ee72b309e5e Mon Sep 17 00:00:00 2001 From: Thierry Ducrest Date: Fri, 25 Aug 2023 13:59:02 +0200 Subject: [PATCH 2/2] Add check options on stock_location_package_restriction --- .../models/stock_move.py | 27 ++++++++++++++----- 1 file changed, 21 insertions(+), 6 deletions(-) diff --git a/stock_location_package_restriction/models/stock_move.py b/stock_location_package_restriction/models/stock_move.py index 9f999ee4be3a..3e7c0849c39b 100644 --- a/stock_location_package_restriction/models/stock_move.py +++ b/stock_location_package_restriction/models/stock_move.py @@ -12,16 +12,25 @@ class StockMove(models.Model): _inherit = "stock.move" - def _check_location_package_restriction(self): - """ - Check if the current stock.move can be executed - regarding a potential package restriction + def _check_location_package_restriction( + self, new_location=None, only_qty_done=True + ): + """Check if the moves can be done regarding potential package restrictions + + By default will only check move lines with a quantity done and their set + destination location. + + If `new_location` is set it will be use as destination location. + If `only_qty_done` is False the check is executed on all + related move lines. + """ Package = self.env["stock.quant.package"] error_msgs = [] + dest_location = new_location or self.move_line_ids.location_dest_id quants_grouped = self.env["stock.quant"].read_group( [ - ("location_id", "in", self.move_line_ids.location_dest_id.ids), + ("location_id", "in", dest_location.ids), ("location_id.package_restriction", "!=", False), ("quantity", ">", 0), ], @@ -31,13 +40,19 @@ def _check_location_package_restriction(self): location_packages = { g["location_id"][0]: set(g["package_id"]) for g in quants_grouped } - lines_being_processed = self.move_line_ids.filtered(lambda line: line.qty_done) + lines_being_processed = ( + self.move_line_ids.filtered(lambda line: line.qty_done) + if only_qty_done + else self.move_line_ids + ) for location, move_lines in groupby( lines_being_processed, lambda m: m.location_dest_id ): if not location.package_restriction: continue + if new_location: + location = new_location existing_package_ids = location_packages.get(location.id, set()) existing_packages = Package.browse(existing_package_ids).exists() new_packages = Package.browse()