109 lines
4.1 KiB
Python
109 lines
4.1 KiB
Python
|
# -*- coding: utf-8 -*-
|
||
|
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||
|
|
||
|
from odoo.exceptions import ValidationError
|
||
|
|
||
|
from odoo.addons.uom.tests.common import UomCommon
|
||
|
|
||
|
|
||
|
class TestUom(UomCommon):
|
||
|
|
||
|
def test_10_conversion(self):
|
||
|
qty = self.uom_gram._compute_quantity(1020000, self.uom_ton)
|
||
|
self.assertEqual(qty, 1.02, "Converted quantity does not correspond.")
|
||
|
|
||
|
price = self.uom_gram._compute_price(2, self.uom_ton)
|
||
|
self.assertEqual(price, 2000000.0, "Converted price does not correspond.")
|
||
|
|
||
|
# If the conversion factor for Dozens (1/12) is not stored with sufficient precision,
|
||
|
# the conversion of 1 Dozen into Units will give e.g. 12.00000000000047 Units
|
||
|
# and the Unit rounding will round that up to 13.
|
||
|
# This is a partial regression test for rev. 311c77bb, which is further improved
|
||
|
# by rev. fa2f7b86.
|
||
|
qty = self.uom_dozen._compute_quantity(1, self.uom_unit)
|
||
|
self.assertEqual(qty, 12.0, "Converted quantity does not correspond.")
|
||
|
|
||
|
# Regression test for side-effect of commit 311c77bb - converting 1234 Grams
|
||
|
# into Kilograms should work even if grams are rounded to 1.
|
||
|
self.uom_gram.write({'rounding': 1})
|
||
|
qty = self.uom_gram._compute_quantity(1234, self.uom_kgm)
|
||
|
self.assertEqual(qty, 1.24, "Converted quantity does not correspond.")
|
||
|
|
||
|
def test_20_rounding(self):
|
||
|
product_uom = self.env['uom.uom'].create({
|
||
|
'name': 'Score',
|
||
|
'factor_inv': 20,
|
||
|
'uom_type': 'bigger',
|
||
|
'rounding': 1.0,
|
||
|
'category_id': self.env.ref('uom.product_uom_categ_unit').id
|
||
|
})
|
||
|
|
||
|
qty = self.uom_unit._compute_quantity(2, product_uom)
|
||
|
self.assertEqual(qty, 1, "Converted quantity should be rounded up.")
|
||
|
|
||
|
def test_30_reference_uniqueness(self):
|
||
|
""" Check the uniqueness of the reference UoM in a category """
|
||
|
time_category = self.env.ref('uom.product_uom_categ_unit')
|
||
|
|
||
|
with self.assertRaises(ValidationError):
|
||
|
self.env['uom.uom'].create({
|
||
|
'name': 'Second Time Reference',
|
||
|
'factor_inv': 1,
|
||
|
'uom_type': 'reference',
|
||
|
'rounding': 1.0,
|
||
|
'category_id': time_category.id
|
||
|
})
|
||
|
|
||
|
def test_40_custom_uom(self):
|
||
|
""" A custom UoM is an UoM in a category without measurement type. It should behave like a normal UoM """
|
||
|
category = self.env['uom.category'].create({
|
||
|
'name': 'Custom UoM category',
|
||
|
})
|
||
|
|
||
|
# at first we can not create a non reference in custom category
|
||
|
with self.assertRaises(ValidationError):
|
||
|
self.env['uom.uom'].create({
|
||
|
'name': 'Bigger UoM of my category',
|
||
|
'factor_inv': 42,
|
||
|
'uom_type': 'bigger',
|
||
|
'rounding': 0.5,
|
||
|
'category_id': category.id
|
||
|
})
|
||
|
|
||
|
# create the reference
|
||
|
self.env['uom.uom'].create({
|
||
|
'name': 'Reference UoM of my category',
|
||
|
'factor_inv': 1,
|
||
|
'uom_type': 'reference',
|
||
|
'rounding': 1.0,
|
||
|
'category_id': category.id
|
||
|
})
|
||
|
|
||
|
# we can create another UoM now
|
||
|
self.env['uom.uom'].create({
|
||
|
'name': 'Bigger UoM of my category',
|
||
|
'factor_inv': 42,
|
||
|
'uom_type': 'bigger',
|
||
|
'rounding': 0.5,
|
||
|
'category_id': category.id
|
||
|
})
|
||
|
|
||
|
# we can not create a second reference in custom category
|
||
|
with self.assertRaises(ValidationError):
|
||
|
self.env['uom.uom'].create({
|
||
|
'name': 'Second Time Reference',
|
||
|
'factor_inv': 1,
|
||
|
'uom_type': 'reference',
|
||
|
'rounding': 1.0,
|
||
|
'category_id': category.id
|
||
|
})
|
||
|
|
||
|
def test_50_check_ratio(self):
|
||
|
with self.assertRaises(ValidationError):
|
||
|
self.env['uom.uom'].create({
|
||
|
'name': 'Custom UoM',
|
||
|
'uom_type': 'bigger',
|
||
|
'ratio': 0,
|
||
|
'category_id': self.env.ref('uom.product_uom_categ_unit').id
|
||
|
})
|