summaryrefslogtreecommitdiff
path: root/addons/base_import/models/test_models.py
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/base_import/models/test_models.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/base_import/models/test_models.py')
-rw-r--r--addons/base_import/models/test_models.py108
1 files changed, 108 insertions, 0 deletions
diff --git a/addons/base_import/models/test_models.py b/addons/base_import/models/test_models.py
new file mode 100644
index 00000000..af025573
--- /dev/null
+++ b/addons/base_import/models/test_models.py
@@ -0,0 +1,108 @@
+# -*- coding: utf-8 -*-
+from odoo import fields, models
+
+
+def model(suffix_name):
+ return 'base_import.tests.models.%s' % suffix_name
+
+
+class Char(models.Model):
+ _name = model('char')
+ _description = 'Tests : Base Import Model, Character'
+
+ value = fields.Char()
+class CharRequired(models.Model):
+ _name = model('char.required')
+ _description = 'Tests : Base Import Model, Character required'
+
+ value = fields.Char(required=True)
+
+class CharReadonly(models.Model):
+ _name = model('char.readonly')
+ _description = 'Tests : Base Import Model, Character readonly'
+
+ value = fields.Char(readonly=True)
+
+class CharStates(models.Model):
+ _name = model('char.states')
+ _description = 'Tests : Base Import Model, Character states'
+
+ value = fields.Char(readonly=True, states={'draft': [('readonly', False)]})
+
+class CharNoreadonly(models.Model):
+ _name = model('char.noreadonly')
+ _description = 'Tests : Base Import Model, Character No readonly'
+
+ value = fields.Char(readonly=True, states={'draft': [('invisible', True)]})
+
+class CharStillreadonly(models.Model):
+ _name = model('char.stillreadonly')
+ _description = 'Tests : Base Import Model, Character still readonly'
+
+ value = fields.Char(readonly=True, states={'draft': [('readonly', True)]})
+
+# TODO: complex field (m2m, o2m, m2o)
+class M2o(models.Model):
+ _name = model('m2o')
+ _description = 'Tests : Base Import Model, Many to One'
+
+ value = fields.Many2one(model('m2o.related'))
+
+class M2oRelated(models.Model):
+ _name = model('m2o.related')
+ _description = 'Tests : Base Import Model, Many to One related'
+
+ value = fields.Integer(default=42)
+
+class M2oRequired(models.Model):
+ _name = model('m2o.required')
+ _description = 'Tests : Base Import Model, Many to One required'
+
+ value = fields.Many2one(model('m2o.required.related'), required=True)
+
+class M2oRequiredRelated(models.Model):
+ _name = model('m2o.required.related')
+ _description = 'Tests : Base Import Model, Many to One required related'
+
+ value = fields.Integer(default=42)
+
+class O2m(models.Model):
+ _name = model('o2m')
+ _description = 'Tests : Base Import Model, One to Many'
+
+ name = fields.Char()
+ value = fields.One2many(model('o2m.child'), 'parent_id')
+
+class O2mChild(models.Model):
+ _name = model('o2m.child')
+ _description = 'Tests : Base Import Model, One to Many child'
+
+ parent_id = fields.Many2one(model('o2m'))
+ value = fields.Integer()
+
+class PreviewModel(models.Model):
+ _name = model('preview')
+ _description = 'Tests : Base Import Model Preview'
+
+ name = fields.Char('Name')
+ somevalue = fields.Integer(string='Some Value', required=True)
+ othervalue = fields.Integer(string='Other Variable')
+
+class FloatModel(models.Model):
+ _name = model('float')
+ _description = 'Tests: Base Import Model Float'
+
+ value = fields.Float()
+ value2 = fields.Monetary()
+ currency_id = fields.Many2one('res.currency')
+
+class ComplexModel(models.Model):
+ _name = model('complex')
+ _description = 'Tests: Base Import Model Complex'
+
+ f = fields.Float()
+ m = fields.Monetary()
+ c = fields.Char()
+ currency_id = fields.Many2one('res.currency')
+ d = fields.Date()
+ dt = fields.Datetime()