From acd5960fc2fbe55959e889e15b79a5c372d0c025 Mon Sep 17 00:00:00 2001 From: Carmen Bianca BAKKER Date: Thu, 4 Jul 2024 14:15:02 +0200 Subject: [PATCH] [FIX] hr_timesheet_overtime: Make write function accept multiple records I'm really not sure how this ever did not break before. Signed-off-by: Carmen Bianca BAKKER --- .../models/account_analytic_line.py | 10 ++++-- hr_timesheet_overtime/tests/test_overtime.py | 31 +++++++++++++++++++ 2 files changed, 39 insertions(+), 2 deletions(-) diff --git a/hr_timesheet_overtime/models/account_analytic_line.py b/hr_timesheet_overtime/models/account_analytic_line.py index 47b82d8..6440839 100644 --- a/hr_timesheet_overtime/models/account_analytic_line.py +++ b/hr_timesheet_overtime/models/account_analytic_line.py @@ -23,8 +23,14 @@ def create(self, vals_list): def write(self, values): if not self.env.context.get("create"): # sale module - self._update_values(values) - return super().write(values) + for record in self: + # TODO: this is slow and inefficient. + vals_copy = values.copy() + record._update_values(vals_copy) + super(AnalyticLine, record).write(vals_copy) + return True + else: + return super().write(values) def _update_values(self, values): """ diff --git a/hr_timesheet_overtime/tests/test_overtime.py b/hr_timesheet_overtime/tests/test_overtime.py index 52f12e9..12fa8b1 100644 --- a/hr_timesheet_overtime/tests/test_overtime.py +++ b/hr_timesheet_overtime/tests/test_overtime.py @@ -421,3 +421,34 @@ def test_stored_change_today(self): self.assertEqual(self.ts1.working_time, 9 * 5) # Affected by the extra overtime self.assertEqual(self.ts1.timesheet_overtime, 2) + + def test_write_multiple_lines(self): + """When writing multiple analytic lines, overtime rates are applied + separately to each record. + """ + overtime = self.env["resource.overtime"].create({"name": "test"}) + self.env["resource.overtime.rate"].create( + { + "name": "test", + "dayofweek": "0", # Monday + "rate": 2.0, + "overtime_id": overtime.id, + } + ) + + lines = self.env["account.analytic.line"].browse() + # monday and tuesday + for day in range(9, 11): + lines += self.env["account.analytic.line"].create( + { + "project_id": self.project_01.id, + "amount": 0.0, + "date": date(2019, 12, day), + "name": "-", + "employee_id": self.employee1.id, + } + ) + lines.write({"unit_amount": 1}) + + self.assertEqual(lines[0].unit_amount, 2) + self.assertEqual(lines[1].unit_amount, 1)