summaryrefslogtreecommitdiff
path: root/addons/test_mail/tests/test_mail_template.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/test_mail/tests/test_mail_template.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/test_mail/tests/test_mail_template.py')
-rw-r--r--addons/test_mail/tests/test_mail_template.py169
1 files changed, 169 insertions, 0 deletions
diff --git a/addons/test_mail/tests/test_mail_template.py b/addons/test_mail/tests/test_mail_template.py
new file mode 100644
index 00000000..5bf72f3d
--- /dev/null
+++ b/addons/test_mail/tests/test_mail_template.py
@@ -0,0 +1,169 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+import base64
+
+from odoo.addons.test_mail.tests.common import TestMailCommon, TestRecipients
+from odoo.tools import mute_logger
+
+
+class TestMailTemplate(TestMailCommon, TestRecipients):
+
+ @classmethod
+ def setUpClass(cls):
+ super(TestMailTemplate, cls).setUpClass()
+ cls.test_record = cls.env['mail.test.simple'].with_context(cls._test_context).create({'name': 'Test', 'email_from': 'ignasse@example.com'})
+
+ cls.user_employee.write({
+ 'groups_id': [(4, cls.env.ref('base.group_partner_manager').id)],
+ })
+
+ cls._attachments = [{
+ 'name': 'first.txt',
+ 'datas': base64.b64encode(b'My first attachment'),
+ 'res_model': 'res.partner',
+ 'res_id': cls.user_admin.partner_id.id
+ }, {
+ 'name': 'second.txt',
+ 'datas': base64.b64encode(b'My second attachment'),
+ 'res_model': 'res.partner',
+ 'res_id': cls.user_admin.partner_id.id
+ }]
+
+ cls.email_1 = 'test1@example.com'
+ cls.email_2 = 'test2@example.com'
+ cls.email_3 = cls.partner_1.email
+ cls._create_template('mail.test.simple', {
+ 'attachment_ids': [(0, 0, cls._attachments[0]), (0, 0, cls._attachments[1])],
+ 'partner_to': '%s,%s' % (cls.partner_2.id, cls.user_admin.partner_id.id),
+ 'email_to': '%s, %s' % (cls.email_1, cls.email_2),
+ 'email_cc': '%s' % cls.email_3,
+ })
+
+ # admin should receive emails
+ cls.user_admin.write({'notification_type': 'email'})
+ # Force the attachments of the template to be in the natural order.
+ cls.email_template.invalidate_cache(['attachment_ids'], ids=cls.email_template.ids)
+
+ @mute_logger('odoo.addons.mail.models.mail_mail')
+ def test_template_send_email(self):
+ mail_id = self.email_template.send_mail(self.test_record.id)
+ mail = self.env['mail.mail'].sudo().browse(mail_id)
+ self.assertEqual(mail.subject, 'About %s' % self.test_record.name)
+ self.assertEqual(mail.email_to, self.email_template.email_to)
+ self.assertEqual(mail.email_cc, self.email_template.email_cc)
+ self.assertEqual(mail.recipient_ids, self.partner_2 | self.user_admin.partner_id)
+
+ @mute_logger('odoo.addons.mail.models.mail_mail')
+ def test_template_translation(self):
+ self.env['res.lang']._activate_lang('es_ES')
+ self.env.ref('base.module_base')._update_translations(['es_ES'])
+
+ partner = self.env['res.partner'].create({'name': "test", 'lang': 'es_ES'})
+ email_template = self.env['mail.template'].create({
+ 'name': 'TestTemplate',
+ 'subject': 'English Subject',
+ 'body_html': '<p>English Body</p>',
+ 'model_id': self.env['ir.model']._get(partner._name).id,
+ 'lang': '${object.lang}'
+ })
+ # Make sure Spanish translations have not been altered
+ description_translations = self.env['ir.translation'].search([('module', '=', 'base'), ('src', '=', partner._description), ('lang', '=', 'es_ES')])
+ description_translations.update({'value': 'Spanish description'})
+
+ self.env['ir.translation'].create({
+ 'type': 'model',
+ 'name': 'mail.template,subject',
+ 'module': 'mail',
+ 'lang': 'es_ES',
+ 'res_id': email_template.id,
+ 'value': 'Spanish Subject',
+ 'state': 'translated',
+ })
+ self.env['ir.translation'].create({
+ 'type': 'model',
+ 'name': 'mail.template,body_html',
+ 'module': 'mail',
+ 'lang': 'es_ES',
+ 'res_id': email_template.id,
+ 'value': '<p>Spanish Body</p>',
+ 'state': 'translated',
+ })
+ view = self.env['ir.ui.view'].create({
+ 'name': 'test_layout',
+ 'key': 'test_layout',
+ 'type': 'qweb',
+ 'arch_db': '<body><t t-raw="message.body"/> English Layout <t t-esc="model_description"/></body>'
+ })
+ self.env['ir.model.data'].create({
+ 'name': 'test_layout',
+ 'module': 'test_mail',
+ 'model': 'ir.ui.view',
+ 'res_id': view.id
+ })
+ self.env['ir.translation'].create({
+ 'type': 'model_terms',
+ 'name': 'ir.ui.view,arch_db',
+ 'module': 'test_mail',
+ 'lang': 'es_ES',
+ 'res_id': view.id,
+ 'src': 'English Layout',
+ 'value': 'Spanish Layout',
+ 'state': 'translated',
+ })
+
+ mail_id = email_template.send_mail(partner.id, notif_layout='test_mail.test_layout')
+ mail = self.env['mail.mail'].sudo().browse(mail_id)
+ self.assertEqual(mail.subject, 'Spanish Subject')
+ self.assertEqual(mail.body_html, '<body><p>Spanish Body</p> Spanish Layout Spanish description</body>')
+
+ def test_template_add_context_action(self):
+ self.email_template.create_action()
+
+ # check template act_window has been updated
+ self.assertTrue(bool(self.email_template.ref_ir_act_window))
+
+ # check those records
+ action = self.email_template.ref_ir_act_window
+ self.assertEqual(action.name, 'Send Mail (%s)' % self.email_template.name)
+ self.assertEqual(action.binding_model_id.model, 'mail.test.simple')
+
+ # def test_template_scheduled_date(self):
+ # from unittest.mock import patch
+
+ # self.email_template_in_2_days = self.email_template.copy()
+
+ # with patch('odoo.addons.mail.tests.test_mail_template.datetime', wraps=datetime) as mock_datetime:
+ # mock_datetime.now.return_value = datetime(2017, 11, 15, 11, 30, 28)
+ # mock_datetime.side_effect = lambda *args, **kw: datetime(*args, **kw)
+
+ # self.email_template_in_2_days.write({
+ # 'scheduled_date': "${(datetime.datetime.now() + relativedelta(days=2)).strftime('%s')}" % DEFAULT_SERVER_DATETIME_FORMAT,
+ # })
+
+ # mail_now_id = self.email_template.send_mail(self.test_record.id)
+ # mail_in_2_days_id = self.email_template_in_2_days.send_mail(self.test_record.id)
+
+ # mail_now = self.env['mail.mail'].browse(mail_now_id)
+ # mail_in_2_days = self.env['mail.mail'].browse(mail_in_2_days_id)
+
+ # # mail preparation
+ # self.assertEqual(mail_now.exists() | mail_in_2_days.exists(), mail_now | mail_in_2_days)
+ # self.assertEqual(bool(mail_now.scheduled_date), False)
+ # self.assertEqual(mail_now.state, 'outgoing')
+ # self.assertEqual(mail_in_2_days.state, 'outgoing')
+ # scheduled_date = datetime.strptime(mail_in_2_days.scheduled_date, DEFAULT_SERVER_DATETIME_FORMAT)
+ # date_in_2_days = datetime.now() + timedelta(days = 2)
+ # self.assertEqual(scheduled_date, date_in_2_days)
+ # # self.assertEqual(scheduled_date.month, date_in_2_days.month)
+ # # self.assertEqual(scheduled_date.year, date_in_2_days.year)
+
+ # # Launch the scheduler on the first mail, it should be reported in self.mails
+ # # and the mail_mail is now deleted
+ # self.env['mail.mail'].process_email_queue()
+ # self.assertEqual(mail_now.exists() | mail_in_2_days.exists(), mail_in_2_days)
+
+ # # Launch the scheduler on the first mail, it's still in 'outgoing' state
+ # self.env['mail.mail'].process_email_queue(ids=[mail_in_2_days.id])
+ # self.assertEqual(mail_in_2_days.state, 'outgoing')
+ # self.assertEqual(mail_now.exists() | mail_in_2_days.exists(), mail_in_2_days)