2013-10-21 09:45:33 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from openerp.tests import common
|
|
|
|
|
|
|
|
class TestFloatExport(common.TransactionCase):
|
|
|
|
def setUp(self):
|
|
|
|
super(TestFloatExport, self).setUp()
|
|
|
|
self.Model = self.registry('decimal.precision.test')
|
|
|
|
|
|
|
|
def get_converter(self, name):
|
|
|
|
converter = self.registry('ir.qweb.field.float')
|
[IMP] use model._fields instead of model._all_columns to cover all fields
The old-api model._all_columns contains information about model._columns and
inherited columns. This dictionary is missing new-api computed non-stored
fields, and the new field objects provide a more readable api...
This commit contains the following changes:
- adapt several methods of BaseModel to use fields instead of columns and
_all_columns
- copy all semantic-free attributes of related fields from their source
- add attribute 'group_operator' on integer and float fields
- base, base_action_rule, crm, edi, hr, mail, mass_mailing, pad,
payment_acquirer, share, website, website_crm, website_mail: simply use
_fields instead of _all_columns
- base, decimal_precision, website: adapt qweb rendering methods to use fields
instead of columns
2014-11-03 15:00:50 +00:00
|
|
|
field = self.Model._fields[name]
|
2013-10-21 09:45:33 +00:00
|
|
|
|
|
|
|
return lambda value, options=None: converter.value_to_html(
|
[IMP] use model._fields instead of model._all_columns to cover all fields
The old-api model._all_columns contains information about model._columns and
inherited columns. This dictionary is missing new-api computed non-stored
fields, and the new field objects provide a more readable api...
This commit contains the following changes:
- adapt several methods of BaseModel to use fields instead of columns and
_all_columns
- copy all semantic-free attributes of related fields from their source
- add attribute 'group_operator' on integer and float fields
- base, base_action_rule, crm, edi, hr, mail, mass_mailing, pad,
payment_acquirer, share, website, website_crm, website_mail: simply use
_fields instead of _all_columns
- base, decimal_precision, website: adapt qweb rendering methods to use fields
instead of columns
2014-11-03 15:00:50 +00:00
|
|
|
self.cr, self.uid, value, field, options=options, context=None)
|
2013-10-21 09:45:33 +00:00
|
|
|
|
|
|
|
def test_basic_float(self):
|
|
|
|
converter = self.get_converter('float')
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.0),
|
|
|
|
"42.0")
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.12345),
|
|
|
|
"42.12345")
|
|
|
|
|
|
|
|
converter = self.get_converter('float_2')
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.0),
|
|
|
|
"42.00")
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.12345),
|
|
|
|
"42.12")
|
|
|
|
|
|
|
|
converter = self.get_converter('float_4')
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.0),
|
|
|
|
'42.0000')
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.12345),
|
|
|
|
'42.1234')
|
|
|
|
|
|
|
|
def test_precision_domain(self):
|
|
|
|
DP = self.registry('decimal.precision')
|
|
|
|
DP.create(self.cr, self.uid, {
|
|
|
|
'name': 'A',
|
|
|
|
'digits': 2,
|
|
|
|
})
|
|
|
|
DP.create(self.cr, self.uid, {
|
|
|
|
'name': 'B',
|
|
|
|
'digits': 6,
|
|
|
|
})
|
|
|
|
|
|
|
|
converter = self.get_converter('float')
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.0, {'decimal_precision': 'A'}),
|
|
|
|
'42.00')
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.0, {'decimal_precision': 'B'}),
|
|
|
|
'42.000000')
|
|
|
|
|
|
|
|
converter = self.get_converter('float_4')
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.12345, {'decimal_precision': 'A'}),
|
|
|
|
'42.12')
|
|
|
|
self.assertEqual(
|
|
|
|
converter(42.12345, {'decimal_precision': 'B'}),
|
|
|
|
'42.123450')
|