From e1a117b1033a1c8f304cceaa362965db4ba91275 Mon Sep 17 00:00:00 2001 From: is-ife Date: Mon, 4 Nov 2024 13:47:21 +0100 Subject: [PATCH 1/2] [FIX] maintenance_equipment_sequence: add model_create_multi to create method --- .../models/maintenance.py | 21 ++++++++-------- .../test_maintenance_equipment_sequence.py | 24 +++++++++++++++++++ 2 files changed, 35 insertions(+), 10 deletions(-) diff --git a/maintenance_equipment_sequence/models/maintenance.py b/maintenance_equipment_sequence/models/maintenance.py index c8348060f..e2b5b1079 100644 --- a/maintenance_equipment_sequence/models/maintenance.py +++ b/maintenance_equipment_sequence/models/maintenance.py @@ -63,16 +63,17 @@ def _inverse_seq_number_next(self): sequence = category.sequence_id._get_current_sequence() sequence.sudo().number_next = category.sequence_number_next - @api.model - def create(self, vals): - if not vals.get("sequence_id", False): - if vals.get("sequence_prefix", False): - vals["sequence_id"] = self.sudo()._create_sequence(vals).id - else: - vals["sequence_prefix"] = ( - self.env["ir.sequence"].browse(vals["sequence_id"]).prefix - ) - result = super(MaintenanceEquipmentCategory, self).create(vals) + @api.model_create_multi + def create(self, vals_list): + for vals in vals_list: + if not vals.get("sequence_id", False): + if vals.get("sequence_prefix", False): + vals["sequence_id"] = self.sudo()._create_sequence(vals).id + else: + vals["sequence_prefix"] = ( + self.env["ir.sequence"].browse(vals["sequence_id"]).prefix + ) + result = super().create(vals_list) self._compute_equipment_code() return result diff --git a/maintenance_equipment_sequence/tests/test_maintenance_equipment_sequence.py b/maintenance_equipment_sequence/tests/test_maintenance_equipment_sequence.py index 176cf5a33..b6bb5b6db 100644 --- a/maintenance_equipment_sequence/tests/test_maintenance_equipment_sequence.py +++ b/maintenance_equipment_sequence/tests/test_maintenance_equipment_sequence.py @@ -59,3 +59,27 @@ def test_01_maintenance_equipment_sequence(self): # Remove code and be automatically set to sequence next value equipment_1.write({"serial_no": False}) self.assertEqual(equipment_1.serial_no, "TTC0002") + + def test_02_maintenance_equipment_sequence(self): + """Create an equipment category linked to a default sequence with a prefix, + and verify that the category correctly inherits the sequence prefix. + """ + # Create a sequence + seq_1 = self.sequence_obj.create( + { + "name": "Test Sequence", + "implementation": "no_gap", + "prefix": "TTC_TEST", + "padding": 4, + "number_increment": 1, + "use_date_range": False, + } + ) + # Create an equipment category linked to the sequence + categ_1 = self.maintenance_equipment_categ_obj.create( + { + "name": "Test Category 0", + "sequence_id": seq_1.id, + } + ) + self.assertEqual(categ_1.sequence_prefix, seq_1.prefix) From 140bb16c812617ceb94bf9911c0a2ccdc94f8775 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Niels=20G=C3=B6ttsch?= <121107740+ng-ife@users.noreply.github.com> Date: Mon, 6 Jan 2025 14:48:46 +0100 Subject: [PATCH 2/2] [FIX] maintenance_equipment_sequence: call _compute_equipment_code() on newly created record(s) Co-authored-by: Pedro M. Baeza --- maintenance_equipment_sequence/models/maintenance.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/maintenance_equipment_sequence/models/maintenance.py b/maintenance_equipment_sequence/models/maintenance.py index e2b5b1079..f8b3fcc1a 100644 --- a/maintenance_equipment_sequence/models/maintenance.py +++ b/maintenance_equipment_sequence/models/maintenance.py @@ -74,7 +74,7 @@ def create(self, vals_list): self.env["ir.sequence"].browse(vals["sequence_id"]).prefix ) result = super().create(vals_list) - self._compute_equipment_code() + result._compute_equipment_code() return result def write(self, vals):