From 3e4a5ed007b85fb37bce162877dddc44a18c3c9d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Iv=C3=A0n=20Todorovich?= Date: Tue, 25 Oct 2022 16:41:38 -0300 Subject: [PATCH] [FIX] mrp_bom_attribute_match: write products recordset The check expects a single record, so it should be processed accordingly. --- mrp_bom_attribute_match/models/product.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/mrp_bom_attribute_match/models/product.py b/mrp_bom_attribute_match/models/product.py index 7d34ae507..ec4a9062d 100644 --- a/mrp_bom_attribute_match/models/product.py +++ b/mrp_bom_attribute_match/models/product.py @@ -7,11 +7,13 @@ class ProductTemplate(models.Model): def write(self, vals): res = super().write(vals) - self.check_product_with_component_change_allowed() - self.check_component_change_allowed() + for rec in self: + rec.check_product_with_component_change_allowed() + rec.check_component_change_allowed() return res def check_product_with_component_change_allowed(self): + self.ensure_one() if len(self.attribute_line_ids) > 0 and len(self.bom_ids) > 0: for bom in self.bom_ids: for line in bom.bom_line_ids.filtered( @@ -37,6 +39,7 @@ class ProductTemplate(models.Model): ) def check_component_change_allowed(self): + self.ensure_one() if len(self.attribute_line_ids) > 0: boms = self.get_component_boms() if boms: @@ -59,6 +62,7 @@ class ProductTemplate(models.Model): ) def get_component_boms(self): + self.ensure_one() bom_lines = self.env["mrp.bom.line"].search( [("component_template_id", "=", self._origin.id)] )