wip add tests on record creation
Some checks failed
pre-commit / pre-commit (pull_request) Failing after 1m33s

This commit is contained in:
2025-08-21 16:01:23 +02:00
parent 23fbbddbb2
commit 860ab5da81
4 changed files with 281 additions and 22 deletions

View File

@@ -8,7 +8,7 @@ from odoo.tools.misc import format_date
_logger = logging.getLogger(__name__)
type_mapping = {
type_mapping = { #field types on the left, question types on the right. TODO : what about booleans ?
"char": ["char_box", "numerical_box", "date", "datetime", "simple_choice", "multiple_choice"],
"text": ["char_box", "date", "simple_choice"],
"html": ["text_box", "numerical_box", "datetime", "simple_choice"],
@@ -17,7 +17,7 @@ type_mapping = {
"date": ["date"],
"datetime": ["datetime"],
"many2one": ["simple_choice"],
"many2many": ["multiple_choice"],
"many2many": ["multiple_choice"],
"selection": ["char_box", "simple_choice"]
}
@@ -32,7 +32,7 @@ class SurveyRecordCreationFieldValues(models.Model):
model_id = fields.Many2one('ir.model', related="survey_record_creation_id.model_id")
field_id = fields.Many2one(
'ir.model.fields',
'ir.model.fields',
domain="[('model_id','=',model_id),('readonly','=',False),('ttype','in',['char','selection','text','html','integer','float','date','datetime','many2one','many2many', 'boolean'])]",
ondelete="cascade")
field_relation = fields.Char(related='field_id.relation')
@@ -40,10 +40,10 @@ class SurveyRecordCreationFieldValues(models.Model):
field_help = fields.Html('Help', compute="_compute_field_help")
value_origin = fields.Selection(
[('fixed','Fixed'),('question','Question'),('other_record','From other created record')],
string="Value origin",
required=True,
default='fixed',
[('fixed','Fixed'),('question','Question'),('other_record','From other created record')],
string="Value origin",
required=True,
default='fixed',
help="""* Fixed: you can set the value in value field
* Question: Response of the question will set the value. If you do not see your question, maybe the type of question do not match the type of field
* From other created record: You can set other record creation to link several created records. Can only be used with many2one fields.""")
@@ -57,7 +57,7 @@ class SurveyRecordCreationFieldValues(models.Model):
fixed_value_integer = fields.Integer("Value")
fixed_value_float = fields.Float("Value")
fixed_value_date = fields.Date("Value")
fixed_value_datetime = fields.Datetime("Value")
fixed_value_datetime = fields.Datetime("Value")
fixed_value_boolean = fields.Boolean("Value")
displayed_value = fields.Char("Value", compute="_compute_displayed_value")
@@ -84,7 +84,7 @@ class SurveyRecordCreationFieldValues(models.Model):
record_creation_field_values.allowed_question_ids = None
return
question_domain = [('survey_id','=',record_creation_field_values.survey_id.id)]
if record_creation_field_values.field_id.ttype in ['many2one','many2many']:
question_domain.extend(['|','&',('answer_values_type','=','record'),('model_id','=',record_creation_field_values.field_id.relation),('answer_values_type','=','value')])
if record_creation_field_values.field_id.ttype in type_mapping:
@@ -96,7 +96,7 @@ class SurveyRecordCreationFieldValues(models.Model):
@api.model
def _selection_target_model(self):
return [(model.model, model.name) for model in self.env['ir.model'].sudo().search([])]
def clean_values(self):
# clean values
self.fixed_value_many2many = None
@@ -119,7 +119,7 @@ class SurveyRecordCreationFieldValues(models.Model):
# Set reference field model and select first record
if self.field_id and self.field_id.ttype == 'many2one' and self.field_id.relation:
rec = self.env[self.field_id.relation].search([], limit=1)
if rec:
if rec:
self.fixed_value_many2one = f"{self.field_id.relation},{rec.id}"
else:
model_name = self.env['ir.model'].search([('model','=',self.field_id.relation)]).name
@@ -136,12 +136,12 @@ class SurveyRecordCreationFieldValues(models.Model):
if self.value_origin == 'fixed':
if self.field_type == 'many2one':
if self.fixed_value_many2one:
return self.fixed_value_many2one.id
return self.fixed_value_many2one.id
elif self.field_type == 'many2many':
return [m2m.value_reference.id for m2m in self.fixed_value_many2many if m2m.value_reference]
else:
return self["fixed_value_"+self.field_type]
@api.onchange("fixed_value_char","fixed_value_selection","fixed_value_text","fixed_value_html","fixed_value_integer","fixed_value_float","fixed_value_date","fixed_value_datetime",'fixed_value_many2one', "fixed_value_many2many","other_created_record_id","question_id")
def _compute_displayed_value(self):
@@ -172,7 +172,7 @@ class SurveyRecordCreationFieldValues(models.Model):
record.displayed_value = ""
class SurveyRecordCreationFieldValuesX2m(models.Model):
"""O2m an M2m default values
"""O2m an M2m default values
"""
_name = 'survey.record.creation.field.values.x2m'
@@ -182,16 +182,16 @@ class SurveyRecordCreationFieldValuesX2m(models.Model):
@api.model
def _selection_target_model(self):
return [(model.model, model.name) for model in self.env['ir.model'].sudo().search([])]
@api.onchange('survey_record_creation_field_values_id')
def _onchange_model_name(self):
# Set reference field model and select first record
field = self.survey_record_creation_field_values_id.field_id
field = self.survey_record_creation_field_values_id.field_id
if field and "2many" in field.ttype and field.relation:
rec = self.env[field.relation].search([], limit=1)
if rec:
if rec:
self.value_reference = f"{field.relation},{rec.id}"
else:
model_name = self.env['ir.model'].search([('model','=',field.relation)]).name
raise ValueError(_('You should append at least one record in %s',(model_name,)))
raise ValueError(_('You should append at least one record in %s',(model_name,)))

View File

@@ -41,7 +41,7 @@ class SurveyUserInput(models.Model):
model = record_creation.model_id.model
vals = {}
ModelClass = self.env[model]
for field_value in record_creation.field_values_ids:
if field_value.value_origin == 'fixed':
vals[field_value.field_id.name] = field_value.get_fixed_value_for_record_creation()
@@ -55,7 +55,7 @@ class SurveyUserInput(models.Model):
if field_value.question_id.question_type in ['simple_choice', 'multiple_choice','matrix']:
if field_value.question_id.answer_values_type == 'record':
record_ids = []
for user_input_line in user_input_lines:
for user_input_line in user_input_lines:
if user_input_line.suggested_answer_id and user_input_line.suggested_answer_id.record_id:
record_ids.append(user_input_line.suggested_answer_id.record_id.id)
if field_value.question_id.question_type == 'simple_choice':
@@ -110,8 +110,8 @@ class SurveyUserInput(models.Model):
# Link generated records to user input
self.env['survey.generated.record'].create({
'survey_record_creation_name':record_creation.name,
'survey_record_creation_id':record_creation.id,
'user_input_id':user_input.id,
'survey_record_creation_id':record_creation.id,
'user_input_id':user_input.id,
"created_record_id":"%s,%s" % (model,record.id)
})

View File

@@ -0,0 +1 @@
from . import test_survey_record_creation

View File

@@ -0,0 +1,258 @@
from datetime import date
from odoo.addons.survey.tests.common import SurveyCase
class TestSurveyRecordCreation(SurveyCase):
def setUp(self):
super(TestSurveyRecordCreation, self).setUp()
self.survey = self.env["survey.survey"].create({
"title": "Test Survey",
})
def test_record_is_created(self):
# Easy test to become familiar with the subject
self.question_name = self._add_question(
page=None,
name="Name",
qtype="char_box",
survey_id=self.survey.id,
sequence=1
)
res_partner_model = self.env["ir.model"]._get("res.partner")
self.survey_record_creation = self.env["survey.record.creation"].create(
{
"name": "Contact",
"survey_id": self.survey.id,
"model_id": res_partner_model.id,
}
)
name_field = self.env["ir.model.fields"].search([("model", "=", "res.partner"), ("name", "=", "name")])
self.env["survey.record.creation.field.values"].create(
{
"survey_record_creation_id": self.survey_record_creation.id,
"survey_id": self.survey.id,
"model_id": res_partner_model.id,
"field_id": name_field.id,
"value_origin": "question",
"question_id": self.question_name.id
}
)
self.answer = self._add_answer(survey=self.survey, partner=False, email="jean@test.fr")
self._add_answer_line(question=self.question_name, answer=self.answer, answer_value="Jean")
self.answer._mark_done()
partner = self.env["res.partner"].search(
[("name", "=", "Jean")]
)
self.assertTrue(partner.name == "Jean")
def test_all_types_of_fields(self):
# TODO : types to be tested (and booleans ?) Is it useful ??
# text
# html
# datetime
# many2one
# many2many
# selection
self.model_id = self.env["ir.model"]._get("res.partner")
self.survey_record_creation = self.env["survey.record.creation"].create(
{
"name": "Contact",
"survey_id": self.survey.id,
"model_id": self.model_id.id,
}
)
self.answer = self._add_answer(survey=self.survey, partner=False, email="jean@test.fr")
### CHAR field "name" ###
self.question_name = self._add_question(
page=None,
name="Name",
qtype="char_box",
survey_id=self.survey.id,
sequence=1
)
self._add_answer_line(question=self.question_name, answer=self.answer, answer_value="Jean")
name_field = self.env["ir.model.fields"].search([("model", "=", "res.partner"), ("name", "=", "name")])
self.env["survey.record.creation.field.values"].create(
{
"survey_record_creation_id": self.survey_record_creation.id,
"survey_id": self.survey.id,
"model_id": self.model_id.id,
"field_id": name_field.id,
"value_origin": "question",
"question_id": self.question_name.id
}
)
### INTEGER field "color" ###
self.question_color = self._add_question(
page=None,
name="Color",
qtype="numerical_box",
survey_id=self.survey.id,
sequence=1
)
self._add_answer_line(question=self.question_color, answer=self.answer, answer_value=2)
color_field = self.env["ir.model.fields"].search([("model", "=", "res.partner"), ("name", "=", "color")])
self.env["survey.record.creation.field.values"].create(
{
"survey_record_creation_id": self.survey_record_creation.id,
"survey_id": self.survey.id,
"model_id": self.model_id.id,
"field_id": color_field.id,
"value_origin": "question",
"question_id": self.question_color.id
}
)
self.answer._mark_done()
partner = self.env["res.partner"].search(
[("name", "=", "Jean"), ("color", "=", 2)]
)
self.assertTrue(partner.name == "Jean")
### FLOAT field "partner_latitude" ###
self.question_partner_latitude = self._add_question(
page=None,
name="Partner latitude",
qtype="numerical_box",
survey_id=self.survey.id,
sequence=1
)
self._add_answer_line(question=self.question_partner_latitude, answer=self.answer, answer_value=44.73333)
partner_latitude_field = self.env["ir.model.fields"].search(
[("model", "=", "res.partner"), ("name", "=", "partner_latitude")])
self.env["survey.record.creation.field.values"].create(
{
"survey_record_creation_id": self.survey_record_creation.id,
"survey_id": self.survey.id,
"model_id": self.model_id.id,
"field_id": partner_latitude_field.id,
"value_origin": "question",
"question_id": self.question_partner_latitude.id
}
)
### DATE field "date" ###
self.question_date = self._add_question(
page=None,
name="Date",
qtype="date",
survey_id=self.survey.id,
sequence=1
)
self._add_answer_line(question=self.question_date, answer=self.answer, answer_value=date.today())
date_field = self.env["ir.model.fields"].search(
[("model", "=", "res.partner"), ("name", "=", "date")])
self.env["survey.record.creation.field.values"].create(
{
"survey_record_creation_id": self.survey_record_creation.id,
"survey_id": self.survey.id,
"model_id": self.model_id.id,
"field_id": date_field.id,
"value_origin": "question",
"question_id": self.question_date.id
}
)
self.answer._mark_done()
partner = self.env["res.partner"].search(
[("name", "=", "Jean"), ("color", "=", 2), ("partner_latitude", "=", 44.73333), ("date", "=", date.today())]
)
self.assertTrue(partner.name == "Jean")
def test_records_are_created(self):
# we test that several records can be created at the end of the same survey
# concurrently, we test the value_origin "other_record" and "fixed"
self.question_name = self._add_question(
page=None,
name="Name",
qtype="char_box",
survey_id=self.survey.id,
sequence=1
)
res_partner_model = self.env["ir.model"]._get("res.partner")
self.contact_survey_record_creation = self.env["survey.record.creation"].create(
{
"name": "Contact",
"survey_id": self.survey.id,
"model_id": res_partner_model.id,
}
)
name_field = self.env["ir.model.fields"].search([("model", "=", "res.partner"), ("name", "=", "name")])
self.env["survey.record.creation.field.values"].create(
{
"survey_record_creation_id": self.contact_survey_record_creation.id,
"survey_id": self.survey.id,
"model_id": res_partner_model.id,
"field_id": name_field.id,
"value_origin": "question",
"question_id": self.question_name.id
}
)
res_partner_bank_model = self.env["ir.model"]._get("res.partner.bank")
self.bank_survey_record_creation = self.env["survey.record.creation"].create(
{
"name": "Bank",
"survey_id": self.survey.id,
"model_id": res_partner_bank_model.id,
}
)
# Below we test "value_origin": "other_record"
partner_field = self.env["ir.model.fields"].search(
[("model", "=", "res.partner.bank"), ("name", "=", "partner_id")])
self.env["survey.record.creation.field.values"].create(
{
"survey_record_creation_id": self.bank_survey_record_creation.id,
"survey_id": self.survey.id,
"model_id": res_partner_bank_model.id,
"field_id": partner_field.id,
"value_origin": "other_record",
"other_created_record_id": self.contact_survey_record_creation.id
}
)
# Below we test "value_origin": "fixed"
acc_number_field = self.env["ir.model.fields"].search(
[("model", "=", "res.partner.bank"), ("name", "=", "acc_number")])
self.env["survey.record.creation.field.values"].create(
{
"survey_record_creation_id": self.bank_survey_record_creation.id,
"survey_id": self.survey.id,
"model_id": res_partner_bank_model.id,
"field_id": acc_number_field.id,
"value_origin": "fixed",
"fixed_value_char": "FR76 1444 5004 0004 0000 0000 000"
}
)
self.answer = self._add_answer(survey=self.survey, partner=False, email="jean@test.fr")
self._add_answer_line(question=self.question_name, answer=self.answer, answer_value="Jean")
self.answer._mark_done()
partner = self.env["res.partner"].search(
[("name", "=", "Jean")]
)
self.assertTrue(partner.name == "Jean")
bank_account = self.env["res.partner.bank"].search(
[("partner_id", "=", partner.id)]
)
self.assertTrue(bank_account.acc_number == "FR76 1444 5004 0004 0000 0000 000")
def test_records_of_same_model_are_created(self):
# Here we want to test
...