This question has been flagged
1 Reply
8488 Views

I have create contracts and everything is setup for payroll. It works fine, but when an employee register vacation it failed with this error:


Error:

Odoo Server Error

Traceback (most recent call last):

  File "/odoo/odoo-server/odoo/http.py", line 646, in _handle_exception

    return super(JsonRequest, self)._handle_exception(exception)

  File "/odoo/odoo-server/odoo/http.py", line 307, in _handle_exception

    raise pycompat.reraise(type(exception), exception, sys.exc_info()[2])

  File "/odoo/odoo-server/odoo/tools/pycompat.py", line 87, in reraise

    raise value

  File "/odoo/odoo-server/odoo/http.py", line 683, in dispatch

    result = self._call_function(**self.params)

  File "/odoo/odoo-server/odoo/http.py", line 339, in _call_function

    return checked_call(self.db, *args, **kwargs)

  File "/odoo/odoo-server/odoo/service/model.py", line 97, in wrapper

    return f(dbname, *args, **kwargs)

  File "/odoo/odoo-server/odoo/http.py", line 332, in checked_call

    result = self.endpoint(*a, **kw)

  File "/odoo/odoo-server/odoo/http.py", line 927, in __call__

    return self.method(*args, **kw)

  File "/odoo/odoo-server/odoo/http.py", line 512, in response_wrap

    response = f(*args, **kw)

  File "/odoo/odoo-server/addons/web/controllers/main.py", line 924, in call_kw

    return self._call_kw(model, method, args, kwargs)

  File "/odoo/odoo-server/addons/web/controllers/main.py", line 916, in _call_kw

    return call_kw(request.env[model], method, args, kwargs)

  File "/odoo/odoo-server/odoo/api.py", line 689, in call_kw

    return call_kw_multi(method, model, args, kwargs)

  File "/odoo/odoo-server/odoo/api.py", line 680, in call_kw_multi

    result = method(recs, *args, **kwargs)

  File "/odoo/odoo-server/odoo/models.py", line 4996, in onchange

    record._onchange_eval(name, field_onchange[name], result)

  File "/odoo/odoo-server/odoo/models.py", line 4892, in _onchange_eval

    method_res = method(self)

  File "/odoo/odoo-server/addons/hr_payroll/models/hr_payslip.py", line 461, in onchange_employee

    worked_days_line_ids = self.get_worked_day_lines(contracts, date_from, date_to)

  File "/odoo/odoo-server/addons/hr_payroll/models/hr_payslip.py", line 178, in get_worked_day_lines

    for day_intervals in day_leave_intervals:

  File "/odoo/odoo-server/addons/resource/models/resource.py", line 463, in _iter_leave_intervals

    resource_id)

  File "/odoo/odoo-server/addons/resource/models/resource.py", line 393, in _get_day_leave_intervals

    end_datetime=datetime.datetime.combine(day_date, end_time))

  File "/odoo/odoo-server/addons/resource/models/resource.py", line 304, in _get_leave_intervals

    leave_date_to = to_tz(fields.Datetime.from_string(leave.date_to), leave.tz)

  File "/odoo/odoo-server/addons/resource/models/resource.py", line 37, in to_tz

    tz = pytz.timezone(tz_name)

  File "/usr/local/lib/python3.5/dist-packages/pytz/__init__.py", line 173, in timezone

    if zone.upper() == 'UTC':

AttributeError: 'bool' object has no attribute 'upper'


Can you help me?   

Avatar
Discard
Author

any body???

Author Best Answer

First update...

I found out that it is related with Holidays module. If the employee does not have any "absent request", payroll works just fine. As soon as the employee register an "absent request" the problem shows up.


Also, I found out that in the work schedule module you have set the schedule in UTC (calculating UTC times) so the leaves module calculate in the right way the days quantity.


Any clue, about the payroll issue????


I really appreciate your help.


Second update

I found out something today debuging this problem... Actually, two issues:

First: The problem is generated because there is a table where leaves are duplicated from hr_holiday, it's called resource_calendar_leaves, but it has a tz column that is not being filled when copying the value, as hr_holiday uses UTC and does not fill a tz, it leave it null. I set it Default as 'Utc'.

After fixing that, I updated all rows with that value and another problem showed up, "zero division". This was the second issue.

Second Issue: The work schedule cannot be split, it generates a zero division. We have a working schedule from 8am to 12pm and from 1pm to 5pm (8 hours total). So I created a schedule with 2 entries for each day, morning and afternoon. I changed it to one entry per day from 8 to 5 and the problem disappear. But working days are not being calculated right in the payroll. Still checking this "last" issue.

Hope this help somebody else and maybe somebody can help me with the "last" issue.

Avatar
Discard

I am also getting same error, did you find solution .. Please share

Author

Sorry, I’m still looking how to solve it.

Author

Update...

I found out something today debuging this problem... Actually, two issues:

First: The problem is generated because there is a table where leaves are duplicated from hr_holiday, it's called resource_calendar_leaves, but it has a tz column that is not being filled when copying the value, as hr_holiday uses UTC and does not fill a tz, it leave it null. I set it Default as 'Utc'.

After fixing that, I updated all rows with that value and another problem p\showed up, "zero division". This was the second issue.

Second Issue: The work schedule cannot be split, it generates a zero division. We have a working schedule from 8am to 12pm and from 1pm to 5pm (8 hours total). So I created a schedule with 2 entries for each day, morning and afternoon. I changed it to one da from 8 to 5 and the problem disappear. But working days are not being calculated right. Still checking the last issue.

Hope this help somebody else and maybe somebody can help me with the last issue.

My issue got fixed . As you say holiday module stores in UTC format. When I changed date_from and date_to to Date instead of DateTime field, my error stopped appearing but leave hours comes up wrong.

Later I found that, If odoo doesn't find timezone set for user. It assigns UTC time to leave. So I changed all user timezone in user-> preference. Now everything works fine.

Remove all leaves,set timezone for user from preference. Now apply again.

Author

Nice catch!

I'll try that.

hello,

i am facing the same problem, i changed employee timezone but steel have the same error message :

Traceback (most recent call last):

File "/usr/lib/python3/dist-packages/odoo/http.py", line 646, in _handle_exception

return super(JsonRequest, self)._handle_exception(exception)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 307, in _handle_exception

raise pycompat.reraise(type(exception), exception, sys.exc_info()[2])

File "/usr/lib/python3/dist-packages/odoo/tools/pycompat.py", line 87, in reraise

raise value

File "/usr/lib/python3/dist-packages/odoo/http.py", line 683, in dispatch

result = self._call_function(**self.params)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 339, in _call_function

return checked_call(self.db, *args, **kwargs)

File "/usr/lib/python3/dist-packages/odoo/service/model.py", line 97, in wrapper

return f(dbname, *args, **kwargs)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 332, in checked_call

result = self.endpoint(*a, **kw)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 927, in __call__

return self.method(*args, **kw)

File "/usr/lib/python3/dist-packages/odoo/http.py", line 512, in response_wrap

response = f(*args, **kw)

File "/usr/lib/python3/dist-packages/odoo/addons/web/controllers/main.py", line 924, in call_kw

return self._call_kw(model, method, args, kwargs)

File "/usr/lib/python3/dist-packages/odoo/addons/web/controllers/main.py", line 916, in _call_kw

return call_kw(request.env[model], method, args, kwargs)

File "/usr/lib/python3/dist-packages/odoo/api.py", line 689, in call_kw

return call_kw_multi(method, model, args, kwargs)

File "/usr/lib/python3/dist-packages/odoo/api.py", line 680, in call_kw_multi

result = method(recs, *args, **kwargs)

File "/usr/lib/python3/dist-packages/odoo/models.py", line 4993, in onchange

record._onchange_eval(name, field_onchange[name], result)

File "/usr/lib/python3/dist-packages/odoo/models.py", line 4889, in _onchange_eval

method_res = method(self)

File "/usr/lib/python3/dist-packages/odoo/addons/hr_payroll/models/hr_payslip.py", line 464, in onchange_employee

worked_days_line_ids = self.get_worked_day_lines(contracts, date_from, date_to)

File "/usr/lib/python3/dist-packages/odoo/addons/hr_payroll/models/hr_payslip.py", line 178, in get_worked_day_lines

for day_intervals in day_leave_intervals:

File "/usr/lib/python3/dist-packages/odoo/addons/resource/models/resource.py", line 463, in _iter_leave_intervals

resource_id)

File "/usr/lib/python3/dist-packages/odoo/addons/resource/models/resource.py", line 393, in _get_day_leave_intervals

end_datetime=datetime.datetime.combine(day_date, end_time))

File "/usr/lib/python3/dist-packages/odoo/addons/resource/models/resource.py", line 304, in _get_leave_intervals

leave_date_to = to_tz(fields.Datetime.from_string(leave.date_to), leave.tz)

File "/usr/lib/python3/dist-packages/odoo/addons/resource/models/resource.py", line 37, in to_tz

tz = pytz.timezone(tz_name)

File "/usr/local/lib/python3.5/dist-packages/pytz/__init__.py", line 173, in timezone

if zone.upper() == 'UTC':

AttributeError: 'bool' object has no attribute 'upper'

Please how to set default time zone to all employees ?? or give other solution !!

Hi, i found the solution, you have just to give timezone to the user that is managing payroll, if it is undefined in preferences, that's my case