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

Error: "Precision Rounding must be positive" when attempting to process and close and work order

Subscribe

Get notified when there's activity on this post

This question has been flagged
workorderassertionerror
4 Replies
7957 Views
Avatar
Jonah Barrett

When attempting to process a specific work order I am getting an error.

I am unsure how precision rounding is causing an issue with the work order/manufacturing order. It has been submitted to the Odoo bug team but since they have been quite busy for the last few weeks I thought I would check if anyone here has any tips.


Thanks in advance.


The error can be seen below.

Odoo Server Error
Traceback (most recent call last):
  File "/home/odoo/src/odoo/odoo/http.py", line 624, in _handle_exception
    return super(JsonRequest, self)._handle_exception(exception)
  File "/home/odoo/src/odoo/odoo/http.py", line 310, in _handle_exception
    raise pycompat.reraise(type(exception), exception, sys.exc_info()[2])
  File "/home/odoo/src/odoo/odoo/tools/pycompat.py", line 14, in reraise
    raise value
  File "/home/odoo/src/odoo/odoo/http.py", line 669, in dispatch
    result = self._call_function(**self.params)
  File "/home/odoo/src/odoo/odoo/http.py", line 350, in _call_function
    return checked_call(self.db, *args, **kwargs)
  File "/home/odoo/src/odoo/odoo/service/model.py", line 94, in wrapper
    return f(dbname, *args, **kwargs)
  File "/home/odoo/src/odoo/odoo/http.py", line 339, in checked_call
    result = self.endpoint(*a, **kw)
  File "/home/odoo/src/odoo/odoo/http.py", line 915, in __call__
    return self.method(*args, **kw)
  File "/home/odoo/src/odoo/odoo/http.py", line 515, in response_wrap
    response = f(*args, **kw)
  File "/home/odoo/src/odoo/addons/web/controllers/main.py", line 1326, in call_button
    action = self._call_kw(model, method, args, kwargs)
  File "/home/odoo/src/odoo/addons/web/controllers/main.py", line 1314, in _call_kw
    return call_kw(request.env[model], method, args, kwargs)
  File "/home/odoo/src/odoo/odoo/api.py", line 387, in call_kw
    result = _call_kw_multi(method, model, args, kwargs)
  File "/home/odoo/src/odoo/odoo/api.py", line 374, in _call_kw_multi
    result = method(recs, *args, **kwargs)
  File "/home/odoo/src/enterprise/mrp_workorder/models/mrp_workorder.py", line 583, in do_finish
    self.record_production()
  File "/home/odoo/src/enterprise/mrp_workorder/models/mrp_workorder.py", line 525, in record_production
    res = super(MrpProductionWorkcenterLine, self).record_production()
  File "/home/odoo/src/odoo/addons/mrp/models/mrp_workorder.py", line 412, in record_production
    self._update_finished_move()
  File "/home/odoo/src/odoo/addons/mrp/models/mrp_abstract_workorder.py", line 273, in _update_finished_move
    float_round(self.qty_producing, precision_rounding=rounding)
  File "/home/odoo/src/odoo/odoo/tools/float_utils.py", line 55, in float_round
    precision_rounding=precision_rounding)
  File "/home/odoo/src/odoo/odoo/tools/float_utils.py", line 30, in _float_check_precision
    "precision_rounding must be positive, got %s" % precision_rounding
AssertionError: precision_rounding must be positive, got 0.0
0
Avatar
Discard
Avatar
Jonah Barrett
Author Best Answer

The error ended up being unrelated to precision rounding but was caused earlier and wasn't caught until the rounding function.

Location of Error

File "/home/odoo/src/odoo/addons/mrp/models/mrp_abstract_workorder.py", line 273, in _update_finished_move

production_move = self.production_id.move_finished_ids.filtered(
            lambda move: move.product_id == self.product_id and
            move.state not in ('done', 'cancel')
        )

The problem

In the above lambda statement move.product_id was returning the id of the originally selected product which had since been changed so it was being compared to self.product_id which was a different product. The odd part was that in the Odoo interface there was no indication of this issue as everything looked like it was updated to the new product.


My Solution

Not the ideal solution, but I ran a one time scheduled task and updated the finished_product_id to match the new product id.


0
Avatar
Discard
Avatar
Hassan Al-Khursi
Best Answer
precision_rounding should be 0.01 not zero
0
Avatar
Discard
Jonah Barrett
Author

I looked at it appears that all of the products units of measurement have their round set to 0.01 with a few being at 0.001 so the problem may be somewhere else instead?

Hassan Al-Khursi

You need to audit these files

File "/home/odoo/src/odoo/addons/mrp/models/mrp_workorder.py", line 412, in record_production

self._update_finished_move()

File "/home/odoo/src/odoo/addons/mrp/models/mrp_abstract_workorder.py", line 273, in _update_finished_move

float_round(self.qty_producing, precision_rounding=rounding)

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
AssertionError: Element odoo has extra content: data owing to few lines of code in the Email Template XML
assertionerror
Avatar
Avatar
1
Oct 23
3657
V16 Work Order Times
workorder
Avatar
0
Jul 23
2489
Consolidate work orders Solved
workorder
Avatar
Avatar
2
May 23
3861
Work Order Real Duration keeps resetting.
workorder
Avatar
Avatar
1
Oct 22
3273
Auto starting work orders that are back orders (mrp_workorder.py) - Odoo V14
workorder
Avatar
0
Jun 22
4227
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