159 lines
7.3 KiB
Python
159 lines
7.3 KiB
Python
# -*- coding: utf-8 -*-
|
|
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
|
|
|
from datetime import datetime, timedelta
|
|
|
|
from odoo.fields import Datetime as FieldsDatetime
|
|
from odoo.tests.common import users
|
|
from odoo.addons.website.tools import MockRequest
|
|
from odoo.addons.website_event_questions.controllers.main import WebsiteEvent
|
|
from odoo.addons.website_event_questions.tests.common import TestEventQuestionCommon
|
|
|
|
|
|
class TestEventData(TestEventQuestionCommon):
|
|
|
|
@users('user_eventmanager')
|
|
def test_event_type_configuration_from_type(self):
|
|
""" Enure configuration & translations are copied from Event Type on Event creation """
|
|
self.env['res.lang'].sudo()._activate_lang('nl_NL')
|
|
|
|
event_type = self.event_type_questions.with_user(self.env.user)
|
|
event_type_question_nl = event_type.with_context(lang='nl_NL').question_ids[0]
|
|
nl_question_title = "Vraag1"
|
|
nl_answer_name = "V1-Antwoord1"
|
|
event_type_question_nl.title = nl_question_title
|
|
event_type_question_nl.answer_ids[0].name = nl_answer_name
|
|
|
|
event = self.env['event.event'].create({
|
|
'name': 'Event Update Type',
|
|
'event_type_id': event_type.id,
|
|
'date_begin': FieldsDatetime.to_string(datetime.today() + timedelta(days=1)),
|
|
'date_end': FieldsDatetime.to_string(datetime.today() + timedelta(days=15)),
|
|
})
|
|
|
|
self.assertEqual(
|
|
event.question_ids.mapped('question_type'),
|
|
['simple_choice', 'simple_choice', 'text_box'])
|
|
self.assertEqual(event.specific_question_ids.title, 'Question1')
|
|
self.assertEqual(
|
|
set(event.specific_question_ids.mapped('answer_ids.name')),
|
|
set(['Q1-Answer1', 'Q1-Answer2']))
|
|
self.assertEqual(len(event.general_question_ids), 2)
|
|
self.assertEqual(event.general_question_ids[0].title, 'Question2')
|
|
self.assertEqual(event.general_question_ids[1].title, 'Question3')
|
|
self.assertEqual(
|
|
set(event.general_question_ids[0].mapped('answer_ids.name')),
|
|
set(['Q2-Answer1', 'Q2-Answer2']))
|
|
event_question_nl = event.with_context(lang='nl_NL').question_ids[0]
|
|
self.assertEqual(event_question_nl.title, nl_question_title,
|
|
"Question title should be translated.")
|
|
self.assertEqual(event_question_nl.answer_ids[0].name, nl_answer_name,
|
|
"Answer name should be translated.")
|
|
|
|
def test_process_attendees_form(self):
|
|
event = self.env['event.event'].create({
|
|
'name': 'Event Update Type',
|
|
'event_type_id': self.event_type_questions.with_user(self.env.user).id,
|
|
'date_begin': FieldsDatetime.to_string(datetime.today() + timedelta(days=1)),
|
|
'date_end': FieldsDatetime.to_string(datetime.today() + timedelta(days=15)),
|
|
})
|
|
ticket_id_1 = self.env['event.event.ticket'].create([{
|
|
'name': 'Regular',
|
|
'event_id': event.id,
|
|
'seats_max': 200,
|
|
}])
|
|
ticket_id_2 = self.env['event.event.ticket'].create([{
|
|
'name': 'VIP',
|
|
'event_id': event.id,
|
|
'seats_max': 200,
|
|
}])
|
|
|
|
form_details = {
|
|
'1-name': 'Pixis',
|
|
'1-email': 'pixis@gmail.com',
|
|
'1-phone': '+32444444444',
|
|
'1-event_ticket_id': ticket_id_1.id,
|
|
'2-name': 'Geluchat',
|
|
'2-email': 'geluchat@gmail.com',
|
|
'2-phone': '+32777777777',
|
|
'2-event_ticket_id': ticket_id_2.id,
|
|
'question_answer-1-%s' % self.event_question_1.id: '5',
|
|
'question_answer-2-%s' % self.event_question_1.id: '9',
|
|
'question_answer-0-%s' % self.event_question_2.id: '7',
|
|
'question_answer-0-%s' % self.event_question_3.id: 'Free Text',
|
|
}
|
|
|
|
with MockRequest(self.env):
|
|
registrations = WebsiteEvent()._process_attendees_form(event, form_details)
|
|
|
|
self.assertEqual(registrations, [
|
|
{'name': 'Pixis', 'email': 'pixis@gmail.com', 'phone': '+32444444444', 'event_ticket_id': ticket_id_1.id,
|
|
'registration_answer_ids': [
|
|
(0, 0, {'question_id': self.event_question_1.id, 'value_answer_id': 5}),
|
|
(0, 0, {'question_id': self.event_question_2.id, 'value_answer_id': 7}),
|
|
(0, 0, {'question_id': self.event_question_3.id, 'value_text_box': 'Free Text'})]},
|
|
{'name': 'Geluchat', 'email': 'geluchat@gmail.com', 'phone': '+32777777777', 'event_ticket_id': ticket_id_2.id,
|
|
'registration_answer_ids': [
|
|
(0, 0, {'question_id': self.event_question_1.id, 'value_answer_id': 9}),
|
|
(0, 0, {'question_id': self.event_question_2.id, 'value_answer_id': 7}),
|
|
(0, 0, {'question_id': self.event_question_3.id, 'value_text_box': 'Free Text'})]}
|
|
])
|
|
|
|
def test_registration_answer_search(self):
|
|
""" Test our custom name_search implementation in 'event.registration.answer'.
|
|
We search on both the 'value_answer_id' and 'value_text_box' fields to allow users to easily
|
|
filter registrations based on the selected answers of the attendees. """
|
|
|
|
event = self.env['event.event'].create({
|
|
'name': 'Test Event',
|
|
'event_type_id': self.event_type_questions.id,
|
|
'date_begin': FieldsDatetime.to_string(datetime.today() + timedelta(days=1)),
|
|
'date_end': FieldsDatetime.to_string(datetime.today() + timedelta(days=15)),
|
|
})
|
|
|
|
[registration_1, registration_2, registration_3] = self.env['event.registration'].create([{
|
|
'event_id': event.id,
|
|
'partner_id': self.env.user.partner_id.id,
|
|
'registration_answer_ids': [
|
|
(0, 0, {
|
|
'question_id': self.event_question_1.id,
|
|
'value_answer_id': self.event_question_1.answer_ids[0].id,
|
|
}),
|
|
]
|
|
}, {
|
|
'event_id': event.id,
|
|
'partner_id': self.env.user.partner_id.id,
|
|
'registration_answer_ids': [
|
|
(0, 0, {
|
|
'question_id': self.event_question_1.id,
|
|
'value_answer_id': self.event_question_1.answer_ids[1].id,
|
|
}),
|
|
(0, 0, {
|
|
'question_id': self.event_question_3.id,
|
|
'value_text_box': "My Answer",
|
|
}),
|
|
]
|
|
}, {
|
|
'event_id': event.id,
|
|
'partner_id': self.env.user.partner_id.id,
|
|
'registration_answer_ids': [
|
|
(0, 0, {
|
|
'question_id': self.event_question_3.id,
|
|
'value_text_box': "Answer2",
|
|
}),
|
|
]
|
|
}])
|
|
|
|
search_res = self.env['event.registration'].search([
|
|
('registration_answer_ids', 'ilike', 'Answer1')
|
|
])
|
|
# should fetch "registration_1" because the answer to the first question is "Q1-Answer1"
|
|
self.assertEqual(search_res, registration_1)
|
|
|
|
search_res = self.env['event.registration'].search([
|
|
('registration_answer_ids', 'ilike', 'Answer2')
|
|
])
|
|
# should fetch "registration_2" because the answer to the first question is "Q1-Answer2"
|
|
# should fetch "registration_3" because the answer to the third question is "Answer2" (as free text)
|
|
self.assertEqual(search_res, registration_2 | registration_3)
|