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/event_sms/tests | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/event_sms/tests')
| -rw-r--r-- | addons/event_sms/tests/__init__.py | 3 | ||||
| -rw-r--r-- | addons/event_sms/tests/test_sms_schedule.py | 85 |
2 files changed, 88 insertions, 0 deletions
diff --git a/addons/event_sms/tests/__init__.py b/addons/event_sms/tests/__init__.py new file mode 100644 index 00000000..1c217f92 --- /dev/null +++ b/addons/event_sms/tests/__init__.py @@ -0,0 +1,3 @@ +# -*- coding: utf-8 -*- + +from . import test_sms_schedule diff --git a/addons/event_sms/tests/test_sms_schedule.py b/addons/event_sms/tests/test_sms_schedule.py new file mode 100644 index 00000000..b32e939b --- /dev/null +++ b/addons/event_sms/tests/test_sms_schedule.py @@ -0,0 +1,85 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from dateutil.relativedelta import relativedelta + +from odoo.addons.event.tests.common import TestEventCommon +from odoo.addons.phone_validation.tools import phone_validation +from odoo.addons.sms.tests.common import SMSCase + + +class TestSMSSchedule(TestEventCommon, SMSCase): + + @classmethod + def setUpClass(cls): + super(TestSMSSchedule, cls).setUpClass() + + cls.sms_template_sub = cls.env['sms.template'].create({ + 'name': 'Test subscription', + 'model_id': cls.env.ref('event.model_event_registration').id, + 'body': '${object.event_id.organizer_id.name} registration confirmation.', + 'lang': '${object.partner_id.lang}' + }) + cls.sms_template_rem = cls.env['sms.template'].create({ + 'name': 'Test reminder', + 'model_id': cls.env.ref('event.model_event_registration').id, + 'body': '${object.event_id.organizer_id.name} reminder', + 'lang': '${object.partner_id.lang}' + }) + + cls.event_0.write({ + 'event_mail_ids': [ + (0, 0, { # right at subscription + 'interval_unit': 'now', + 'interval_type': 'after_sub', + 'notification_type': 'sms', + 'sms_template_id': cls.sms_template_sub.id}), + (0, 0, { # 3 days before event + 'interval_nbr': 3, + 'interval_unit': 'days', + 'interval_type': 'before_event', + 'notification_type': 'sms', + 'sms_template_id': cls.sms_template_rem.id}), + ] + }) + + def test_sms_schedule(self): + with self.mockSMSGateway(): + self._create_registrations(self.event_0, 3) + + # check subscription scheduler + schedulers = self.env['event.mail'].search([('event_id', '=', self.event_0.id), ('interval_type', '=', 'after_sub')]) + self.assertEqual(len(schedulers), 1) + self.assertEqual(schedulers.scheduled_date, self.event_0.create_date, 'event: incorrect scheduled date for checking controller') + + # verify that subscription scheduler was auto-executed after each registration + self.assertEqual(len(schedulers.mail_registration_ids), 3) + self.assertTrue(all(m.mail_sent is True for m in schedulers.mail_registration_ids)) + self.assertEqual(schedulers.mapped('mail_registration_ids.registration_id'), self.event_0.registration_ids) + sanitized_numbers = [] + for registration in self.event_0.registration_ids: + reg_sanitized_number = phone_validation.phone_format(registration.phone, 'BE', '32', force_format='E164') + sanitized_numbers.append(reg_sanitized_number) + self.assertSMSOutgoing( + self.env['res.partner'], reg_sanitized_number, + content='%s registration confirmation.' % self.event_0.organizer_id.name) + + # clear notification queue to avoid conflicts when checking next notifications + self.env['mail.notification'].search([('sms_number', 'in', sanitized_numbers)]).unlink() + self.env['sms.sms'].search([('number', 'in', sanitized_numbers)]).unlink() + + # check before event scheduler + schedulers = self.env['event.mail'].search([('event_id', '=', self.event_0.id), ('interval_type', '=', 'before_event')]) + self.assertEqual(len(schedulers), 1, 'event: wrong scheduler creation') + self.assertEqual(schedulers[0].scheduled_date, self.event_0.date_begin + relativedelta(days=-3)) + + # execute event reminder scheduler explicitly + with self.mockSMSGateway(): + schedulers.execute() + + # verify that subscription scheduler was auto-executed after each registration + for registration in self.event_0.registration_ids: + reg_sanitized_number = phone_validation.phone_format(registration.phone, 'BE', '32', force_format='E164') + self.assertSMSOutgoing( + self.env['res.partner'], reg_sanitized_number, + content='%s reminder' % self.event_0.organizer_id.name) |
