2018-01-16 11:28:15 +05:30
# -*- coding: utf-8 -*-
2018-01-16 02:34:37 -08:00
# Part of Odoo, Flectra. See LICENSE file for full copyright and licensing details.
2018-01-16 11:28:15 +05:30
2018-07-13 09:21:38 +00:00
from datetime import datetime , time
2018-01-16 11:28:15 +05:30
from dateutil . relativedelta import relativedelta
2018-01-16 02:34:37 -08:00
from flectra import fields
2018-01-16 11:28:15 +05:30
2018-01-16 02:34:37 -08:00
from flectra . tests import common
from flectra . addons . hr_timesheet . tests . test_timesheet import TestTimesheet
2018-01-16 11:28:15 +05:30
class TestTimesheetHolidaysCreate ( common . TransactionCase ) :
def test_status_create ( self ) :
""" Ensure that when a status is created, it fullfills the project and task constrains """
status = self . env [ ' hr.holidays.status ' ] . create ( {
' name ' : ' A nice Leave Type ' ,
' limit ' : True
} )
company = self . env . user . company_id
self . assertEqual ( status . timesheet_project_id , company . leave_timesheet_project_id , ' The default project linked to the status should be the same as the company ' )
self . assertEqual ( status . timesheet_task_id , company . leave_timesheet_task_id , ' The default task linked to the status should be the same as the company ' )
class TestTimesheetHolidays ( TestTimesheet ) :
def setUp ( self ) :
super ( TestTimesheetHolidays , self ) . setUp ( )
self . employee_working_calendar = self . empl_employee . resource_calendar_id
# leave dates : from next monday to next wednesday (to avoid crashing tests on weekend, when
# there is no work days in working calendar)
2018-04-05 13:55:40 +05:30
# NOTE: second and millisecond can add a working days
self . leave_start_datetime = datetime ( 2018 , 2 , 5 , 7 , 0 , 0 , 0 ) # this is monday
2018-01-16 11:28:15 +05:30
self . leave_end_datetime = self . leave_start_datetime + relativedelta ( days = 3 )
# all company have those internal project/task (created by default)
self . internal_project = self . env . user . company_id . leave_timesheet_project_id
self . internal_task_leaves = self . env . user . company_id . leave_timesheet_task_id
self . leave_type_with_ts = self . env [ ' hr.holidays.status ' ] . create ( {
' name ' : ' Leave Type with timesheet generation ' ,
' limit ' : True ,
' timesheet_generate ' : True ,
' timesheet_project_id ' : self . internal_project . id ,
' timesheet_task_id ' : self . internal_task_leaves . id ,
} )
self . leave_type_no_ts = self . env [ ' hr.holidays.status ' ] . create ( {
' name ' : ' Leave Type without timesheet generation ' ,
' limit ' : True ,
' timesheet_generate ' : False ,
' timesheet_project_id ' : False ,
' timesheet_task_id ' : False ,
} )
# HR Officer allocates some leaves to the employee 1
self . Holidays = self . env [ ' hr.holidays ' ] . with_context ( mail_create_nolog = True , mail_notrack = True )
self . leave_allocation_with_ts = self . Holidays . sudo ( ) . create ( {
' name ' : ' Days for limited category with timesheet ' ,
' employee_id ' : self . empl_employee . id ,
' holiday_status_id ' : self . leave_type_with_ts . id ,
' type ' : ' add ' ,
' number_of_days_temp ' : 10 ,
} )
self . leave_allocation_with_ts . action_approve ( )
self . leave_allocation_no_ts = self . Holidays . sudo ( ) . create ( {
' name ' : ' Days for limited category without timesheet ' ,
' employee_id ' : self . empl_employee . id ,
' holiday_status_id ' : self . leave_type_no_ts . id ,
' type ' : ' add ' ,
' number_of_days_temp ' : 10 ,
} )
self . leave_allocation_no_ts . action_approve ( )
def test_validate_with_timesheet ( self ) :
# employee creates a leave request
2018-04-05 13:55:40 +05:30
number_of_days = ( self . leave_end_datetime - self . leave_start_datetime ) . days
2018-01-16 11:28:15 +05:30
holiday = self . Holidays . sudo ( self . user_employee . id ) . create ( {
' name ' : ' Leave 1 ' ,
' employee_id ' : self . empl_employee . id ,
' holiday_status_id ' : self . leave_type_with_ts . id ,
' date_from ' : self . leave_start_datetime ,
' date_to ' : self . leave_end_datetime ,
' number_of_days_temp ' : number_of_days ,
} )
holiday . sudo ( ) . action_validate ( )
self . assertEquals ( len ( holiday . timesheet_ids ) , number_of_days , ' Number of generated timesheets should be the same as the leave duration (1 per day) ' )
# manager refuse the leave
holiday . sudo ( ) . action_refuse ( )
self . assertEquals ( len ( holiday . timesheet_ids ) , 0 , ' Number of linked timesheets should be zero, since the leave is refused. ' )
def test_validate_without_timesheet ( self ) :
# employee creates a leave request
number_of_days = ( self . leave_end_datetime - self . leave_start_datetime ) . days
holiday = self . Holidays . sudo ( self . user_employee . id ) . create ( {
' name ' : ' Leave 1 ' ,
' employee_id ' : self . empl_employee . id ,
' holiday_status_id ' : self . leave_type_no_ts . id ,
' date_from ' : self . leave_start_datetime ,
' date_to ' : self . leave_end_datetime ,
' number_of_days_temp ' : number_of_days ,
} )
holiday . sudo ( ) . action_validate ( )
self . assertEquals ( len ( holiday . timesheet_ids ) , 0 , ' Number of generated timesheets should be zero since the leave type does not generate timesheet ' )