summaryrefslogtreecommitdiff
path: root/addons/hr_holidays/tests/test_change_department.py
diff options
context:
space:
mode:
Diffstat (limited to 'addons/hr_holidays/tests/test_change_department.py')
-rw-r--r--addons/hr_holidays/tests/test_change_department.py67
1 files changed, 67 insertions, 0 deletions
diff --git a/addons/hr_holidays/tests/test_change_department.py b/addons/hr_holidays/tests/test_change_department.py
new file mode 100644
index 00000000..83ebb158
--- /dev/null
+++ b/addons/hr_holidays/tests/test_change_department.py
@@ -0,0 +1,67 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from datetime import datetime
+from dateutil.relativedelta import relativedelta
+
+from odoo.addons.hr_holidays.tests.common import TestHrHolidaysCommon
+
+
+class TestChangeDepartment(TestHrHolidaysCommon):
+ def test_employee_change_department_request_change_department(self):
+ self.HolidaysEmployeeGroup = self.env['hr.leave'].with_user(self.user_employee_id)
+
+ HolidayStatusManagerGroup = self.env['hr.leave.type'].with_user(self.user_hrmanager_id)
+ self.holidays_status_1 = HolidayStatusManagerGroup.create({
+ 'name': 'NotLimitedHR',
+ 'allocation_type': 'no',
+ 'validity_start': False,
+ })
+
+ def create_holiday(name, start, end):
+ return self.HolidaysEmployeeGroup.create({
+ 'name': name,
+ 'employee_id': self.employee_emp_id,
+ 'holiday_status_id': self.holidays_status_1.id,
+ 'date_from': (datetime.today() + relativedelta(days=start)).strftime('%Y-%m-%d %H:%M'),
+ 'date_to': datetime.today() + relativedelta(days=end),
+ 'number_of_days': end-start,
+ })
+
+ # Non approved leave request change department
+ self.employee_emp.department_id = self.rd_dept
+ hol1_employee_group = create_holiday("hol1", 1, 2)
+ self.employee_emp.department_id = self.hr_dept
+ self.assertEqual(hol1_employee_group.department_id, self.hr_dept, 'hr_holidays: non approved leave request should change department if employee change department')
+
+ # Approved passed leave request change department
+ self.employee_emp.department_id = self.hr_dept
+ hol2_employee_group = create_holiday("hol2", -4, -3)
+ hol2_user_group = hol2_employee_group.with_user(self.user_hruser_id)
+ hol2_user_group.action_approve()
+ self.employee_emp.department_id = self.rd_dept
+ self.assertEqual(hol2_employee_group.department_id, self.hr_dept, 'hr_holidays: approved passed leave request should stay in previous department if employee change department')
+
+ # Approved futur leave request change department
+ self.employee_emp.department_id = self.hr_dept
+ hol22_employee_group = create_holiday("hol22", 3, 4)
+ hol22_user_group = hol22_employee_group.with_user(self.user_hruser_id)
+ hol22_user_group.action_approve()
+ self.employee_emp.department_id = self.rd_dept
+ self.assertEqual(hol22_employee_group.department_id, self.rd_dept, 'hr_holidays: approved futur leave request should change department if employee change department')
+
+ # Refused passed leave request change department
+ self.employee_emp.department_id = self.rd_dept
+ hol3_employee_group = create_holiday("hol3", -6, -5)
+ hol3_user_group = hol3_employee_group.with_user(self.user_hruser_id)
+ hol3_user_group.action_refuse()
+ self.employee_emp.department_id = self.hr_dept # Change department
+ self.assertEqual(hol3_employee_group.department_id, self.rd_dept, 'hr_holidays: refused passed leave request should stay in previous department if employee change department')
+
+ # Refused futur leave request change department
+ self.employee_emp.department_id = self.rd_dept
+ hol32_employee_group = create_holiday("hol32", 5, 6)
+ hol32_user_group = hol32_employee_group.with_user(self.user_hruser_id)
+ hol32_user_group.action_refuse()
+ self.employee_emp.department_id = self.hr_dept # Change department
+ self.assertEqual(hol32_employee_group.department_id, self.hr_dept, 'hr_holidays: refused futur leave request should change department if employee change department')