diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/base_import/models/test_models.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/base_import/models/test_models.py')
| -rw-r--r-- | addons/base_import/models/test_models.py | 108 |
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() |
