Skip to Content
Odoo Menu
  • Sign in
  • Try it free
  • Apps
    Finance
    • Accounting
    • Invoicing
    • Expenses
    • Spreadsheet (BI)
    • Documents
    • Sign
    Sales
    • CRM
    • Sales
    • POS Shop
    • POS Restaurant
    • Subscriptions
    • Rental
    Websites
    • Website Builder
    • eCommerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Supply Chain
    • Inventory
    • Manufacturing
    • PLM
    • Purchase
    • Maintenance
    • Quality
    Human Resources
    • Employees
    • Recruitment
    • Time Off
    • Appraisals
    • Referrals
    • Fleet
    Marketing
    • Social Marketing
    • Email Marketing
    • SMS Marketing
    • Events
    • Marketing Automation
    • Surveys
    Services
    • Project
    • Timesheets
    • Field Service
    • Helpdesk
    • Planning
    • Appointments
    Productivity
    • Discuss
    • Approvals
    • IoT
    • VoIP
    • Knowledge
    • WhatsApp
    Third party apps Odoo Studio Odoo Cloud Platform
  • Industries
    Retail
    • Book Store
    • Clothing Store
    • Furniture Store
    • Grocery Store
    • Hardware Store
    • Toy Store
    Food & Hospitality
    • Bar and Pub
    • Restaurant
    • Fast Food
    • Guest House
    • Beverage Distributor
    • Hotel
    Real Estate
    • Real Estate Agency
    • Architecture Firm
    • Construction
    • Estate Management
    • Gardening
    • Property Owner Association
    Consulting
    • Accounting Firm
    • Odoo Partner
    • Marketing Agency
    • Law firm
    • Talent Acquisition
    • Audit & Certification
    Manufacturing
    • Textile
    • Metal
    • Furnitures
    • Food
    • Brewery
    • Corporate Gifts
    Health & Fitness
    • Sports Club
    • Eyewear Store
    • Fitness Center
    • Wellness Practitioners
    • Pharmacy
    • Hair Salon
    Trades
    • Handyman
    • IT Hardware & Support
    • Solar Energy Systems
    • Shoe Maker
    • Cleaning Services
    • HVAC Services
    Others
    • Nonprofit Organization
    • Environmental Agency
    • Billboard Rental
    • Photography
    • Bike Leasing
    • Software Reseller
    Browse all Industries
  • Community
    Learn
    • Tutorials
    • Documentation
    • Certifications
    • Training
    • Blog
    • Podcast
    Empower Education
    • Education Program
    • Scale Up! Business Game
    • Visit Odoo
    Get the Software
    • Download
    • Compare Editions
    • Releases
    Collaborate
    • Github
    • Forum
    • Events
    • Translations
    • Become a Partner
    • Services for Partners
    • Register your Accounting Firm
    Get Services
    • Find a Partner
    • Find an Accountant
    • Meet an advisor
    • Implementation Services
    • Customer References
    • Support
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Get a demo
  • Pricing
  • Help

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Accounting
  • Inventory
  • PoS
  • Project
  • MRP
All apps
You need to be registered to interact with the community.
All Posts People Badges
Tags (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
Tags (View all)
odoo accounting v14 pos v15
About this forum
Help

Payroll and leaves problem - "AttributeError: 'bool' object has no attribute 'upper'" when an employee register vacation

Subscribe

Get notified when there's activity on this post

This question has been flagged
errorpayrollleavesodoo11
1 Reply
9838 Views
Avatar
Carlos Wong

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?   

0
Avatar
Discard
Carlos Wong
Author

any body???

Avatar
Carlos Wong
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.

0
Avatar
Discard
inian

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

Carlos Wong
Author

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

Carlos Wong
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.

inian

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.

inian

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

Carlos Wong
Author

Nice catch!

I'll try that.

B.Khalil

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 !!

B.Khalil

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

Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Sign up
Related Posts Replies Views Activity
"The character encoding of the HTML document was not declared" when connecting to odoo11 server
error odoo11
Avatar
0
Nov 21
4057
Error: The field `effective_date` does not exist - odoo 11
error odoo11
Avatar
Avatar
1
Nov 19
5813
Set leave balance as zero - Odoo 11
leaves odoo11
Avatar
Avatar
1
May 19
3270
How to change the existing model hr.holidays in odoo 11
leaves odoo11
Avatar
0
May 19
4291
Odoo Server Error "unable to create thread pipe"
error reporting odoo11
Avatar
0
Jan 22
4897
Community
  • Tutorials
  • Documentation
  • Forum
Open Source
  • Download
  • Github
  • Runbot
  • Translations
Services
  • Odoo.sh Hosting
  • Support
  • Upgrade
  • Custom Developments
  • Education
  • Find an Accountant
  • Find a Partner
  • Become a Partner
About us
  • Our company
  • Brand Assets
  • Contact us
  • Jobs
  • Events
  • Podcast
  • Blog
  • Customers
  • Legal • Privacy
  • Security
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo is a suite of open source business apps that cover all your company needs: CRM, eCommerce, accounting, inventory, point of sale, project management, etc.

Odoo's unique value proposition is to be at the same time very easy to use and fully integrated.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now