mirror of
https://github.com/bringout/oca-ocb-core.git
synced 2026-04-20 07:12:02 +02:00
229 lines
12 KiB
Python
229 lines
12 KiB
Python
# -*- coding: utf-8 -*-
|
|
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
|
|
|
from odoo.addons.mail.tests.common import MailCommon
|
|
from odoo.tests import tagged, users
|
|
|
|
|
|
@tagged('mail_tools', 'res_partner')
|
|
class TestMailTools(MailCommon):
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
super(TestMailTools, cls).setUpClass()
|
|
|
|
cls._test_email = 'alfredoastaire@test.example.com'
|
|
cls.test_partner = cls.env['res.partner'].create({
|
|
'country_id': cls.env.ref('base.be').id,
|
|
'email': cls._test_email,
|
|
'name': 'Alfred Astaire',
|
|
'phone': '0456334455',
|
|
})
|
|
|
|
@users('employee')
|
|
def test_find_partner_from_emails(self):
|
|
Partner = self.env['res.partner']
|
|
test_partner = Partner.browse(self.test_partner.ids)
|
|
self.assertEqual(test_partner.email, self._test_email)
|
|
|
|
sources = [
|
|
self._test_email, # test direct match
|
|
f'"Norbert Poiluchette" <{self._test_email}>', # encapsulated
|
|
'fredoastaire@test.example.com', # partial email -> should not match !
|
|
]
|
|
expected_partners = [
|
|
test_partner,
|
|
test_partner,
|
|
self.env['res.partner'],
|
|
]
|
|
for source, expected_partner in zip(sources, expected_partners):
|
|
with self.subTest(source=source):
|
|
found = Partner._mail_find_partner_from_emails([source])
|
|
self.assertEqual(found, [expected_partner])
|
|
|
|
# test with wildcard "_"
|
|
found = Partner._mail_find_partner_from_emails(['alfred_astaire@test.example.com'])
|
|
self.assertEqual(found, [self.env['res.partner']])
|
|
|
|
# test partners with encapsulated emails
|
|
# ------------------------------------------------------------
|
|
test_partner.sudo().write({'email': f'"Alfred Mighty Power Astaire" <{self._test_email}>'})
|
|
|
|
sources = [
|
|
self._test_email, # test direct match
|
|
f'"Norbert Poiluchette" <{self._test_email}>', # encapsulated
|
|
]
|
|
expected_partners = [
|
|
test_partner,
|
|
test_partner,
|
|
]
|
|
for source, expected_partner in zip(sources, expected_partners):
|
|
with self.subTest(source=source):
|
|
found = Partner._mail_find_partner_from_emails([source])
|
|
self.assertEqual(found, [expected_partner])
|
|
|
|
# test with wildcard "_"
|
|
found = Partner._mail_find_partner_from_emails(['alfred_astaire@test.example.com'])
|
|
self.assertEqual(found, [self.env['res.partner']])
|
|
|
|
def test_mail_find_partner_from_emails_alias_localpart(self):
|
|
""" Test mail_find_partner_from_emails when dealing with aliases that
|
|
have alias_incoming_local enabled and emails include the local part. """
|
|
self.env['mail.alias'].create([{
|
|
'alias_name': 'test_localpart',
|
|
'alias_domain_id': self.env.company.alias_domain_id.id,
|
|
'alias_incoming_local': True,
|
|
'alias_model_id': self.env.ref('mail.model_res_partner').id,
|
|
}])
|
|
|
|
found = self.env['mail.thread']._partner_find_from_emails_single(['test_localpart@gmail.com'], no_create=False)
|
|
self.assertFalse(found, f'Found {found.email} / {found.name} instead of empty recordset')
|
|
|
|
# limit incoming-compat aliases to a fixed set of domains
|
|
self.env['ir.config_parameter'].set_param('mail.catchall.domain.allowed', "tartopoils.com, brutijus.com")
|
|
for test_email, email_normalized, done in [
|
|
('"Customer" <test_localpart@gmail.com>', 'test_localpart@gmail.com', True),
|
|
('"Customer" <test_localpart@tartopoils.com>', 'test_localpart@tartopoils.com', False),
|
|
('"Customer" <test_localpart@brutijus.com>', 'test_localpart@brutijus.com', False),
|
|
('"Customer" <test_localpart@brutijus.fr.com>', 'test_localpart@brutijus.fr.com', True),
|
|
]:
|
|
with self.subTest(check="Allowed domain support", test_email=test_email):
|
|
found = self.env['mail.thread']._partner_find_from_emails_single([test_email], no_create=False)
|
|
if not done:
|
|
self.assertFalse(found, f'Found {found.email} / {found.name} instead of empty recordset')
|
|
else:
|
|
self.assertTrue(found, 'Should have created a partner')
|
|
self.assertEqual(found.email_normalized, email_normalized)
|
|
self.assertEqual(found.name, 'Customer')
|
|
|
|
found = self.env['mail.thread']._partner_find_from_emails_single(['"Customer" <test_no_localpart@gmail.com>'], no_create=False)
|
|
self.assertTrue(found, 'Should have created a partner')
|
|
self.assertEqual(found.email_normalized, 'test_no_localpart@gmail.com')
|
|
self.assertEqual(found.name, 'Customer')
|
|
|
|
@users('employee')
|
|
def test_mail_find_partner_from_emails_followers(self):
|
|
""" Test '_mail_find_partner_from_emails' when dealing with records on
|
|
which followers have to be found based on email. Check multi email
|
|
and encapsulated email support. """
|
|
# create partner just for the follow mechanism
|
|
linked_record = self.env['res.partner'].sudo().create({'name': 'Record for followers'})
|
|
follower_partner = self.env['res.partner'].sudo().create({
|
|
'email': self._test_email,
|
|
'name': 'Duplicated, follower of record',
|
|
})
|
|
linked_record.message_subscribe(partner_ids=follower_partner.ids)
|
|
test_partner = self.test_partner.with_env(self.env)
|
|
|
|
# standard test, no multi-email, to assert base behavior
|
|
cases = [(self._test_email, True), (self._test_email, False)]
|
|
for source, follower_check in cases:
|
|
expected_partner = follower_partner if follower_check else test_partner
|
|
with self.subTest(source=source, follower_check=follower_check):
|
|
partner = self.env['res.partner']._mail_find_partner_from_emails(
|
|
[source], records=linked_record if follower_check else None
|
|
)[0]
|
|
self.assertEqual(partner, expected_partner)
|
|
|
|
# formatted email
|
|
encapsulated_test_email = f'"Robert Astaire" <{self._test_email}>'
|
|
(follower_partner + test_partner).sudo().write({'email': encapsulated_test_email})
|
|
cases = [
|
|
(self._test_email, True), # normalized
|
|
(self._test_email, False), # normalized
|
|
(encapsulated_test_email, True), # encapsulated, same
|
|
(encapsulated_test_email, False), # encapsulated, same
|
|
(f'"AnotherName" <{self._test_email}', True), # same normalized, other name
|
|
(f'"AnotherName" <{self._test_email}', False), # same normalized, other name
|
|
]
|
|
for source, follower_check in cases:
|
|
expected_partner = follower_partner if follower_check else test_partner
|
|
with self.subTest(source=source, follower_check=follower_check):
|
|
partner = self.env['res.partner']._mail_find_partner_from_emails(
|
|
[source], records=linked_record if follower_check else None
|
|
)[0]
|
|
self.assertEqual(partner, expected_partner,
|
|
'Mail: formatted email is recognized through usage of normalized email')
|
|
|
|
# multi-email
|
|
_test_email_2 = '"Robert Astaire" <not.alfredoastaire@test.example.com>'
|
|
(follower_partner + test_partner).sudo().write({'email': f'{self._test_email}, {_test_email_2}'})
|
|
cases = [
|
|
(self._test_email, True, follower_partner), # first email
|
|
(self._test_email, False, test_partner), # first email
|
|
(_test_email_2, True, self.env['res.partner']), # second email
|
|
(_test_email_2, False, self.env['res.partner']), # second email
|
|
('not.alfredoastaire@test.example.com', True, self.env['res.partner']), # normalized second email in field
|
|
('not.alfredoastaire@test.example.com', False, self.env['res.partner']), # normalized second email in field
|
|
(f'{self._test_email}, {_test_email_2}', True, follower_partner), # multi-email, both matching, depends on comparison
|
|
(f'{self._test_email}, {_test_email_2}', False, test_partner), # multi-email, both matching, depends on comparison
|
|
]
|
|
for source, follower_check, expected_partner in cases:
|
|
with self.subTest(source=source, follower_check=follower_check):
|
|
partner = self.env['res.partner']._mail_find_partner_from_emails(
|
|
[source], records=linked_record if follower_check else None
|
|
)[0]
|
|
self.assertEqual(partner, expected_partner,
|
|
'Mail (FIXME): partial recognition of multi email through email_normalize')
|
|
|
|
# test users with same email, priority given to current user
|
|
# --------------------------------------------------------------
|
|
self.user_employee.sudo().write({'email': '"Alfred Astaire" <%s>' % self.env.user.partner_id.email_normalized})
|
|
found = self.env['res.partner']._mail_find_partner_from_emails([self.env.user.partner_id.email_formatted])
|
|
self.assertEqual(found, [self.env.user.partner_id])
|
|
|
|
def test_mail_find_partner_from_emails_multicompany(self):
|
|
""" Test _mail_find_partner_from_emails when dealing with records in
|
|
a multicompany environment, returning a partner record with matching
|
|
company_id. """
|
|
Partner = self.env['res.partner']
|
|
self.test_partner.company_id = self.company_2
|
|
self.test_partner.write({'name': 'Original - Company2'})
|
|
|
|
test_partner_no_company = self.test_partner.copy({'name': 'NoCompany', 'company_id': False})
|
|
test_partner_company_2 = self.test_partner
|
|
test_partner_company_3 = test_partner_no_company.copy({'name': 'Company3', 'company_id': self.company_3.id})
|
|
records = [
|
|
None,
|
|
*Partner.create([
|
|
{'name': 'Company 2 contact', 'company_id': self.company_2.id},
|
|
{'name': 'Company 3 contact', 'company_id': self.company_3.id},
|
|
{'name': 'No restrictions', 'company_id': False},
|
|
])
|
|
]
|
|
expected_partners = [
|
|
(test_partner_no_company, "W/out reference record, prefer non-specific partner."),
|
|
(test_partner_company_2, "Prefer same company as reference record."),
|
|
(test_partner_company_3, "Prefer same company as reference record."),
|
|
(test_partner_no_company, "Prefer non-specific partner for non-specific records."),
|
|
]
|
|
for record, (expected, msg) in zip(records, expected_partners):
|
|
with self.subTest(record=record.name if record else 'NoRecord'):
|
|
found = Partner._mail_find_partner_from_emails([self._test_email], records=record)
|
|
self.assertEqual(found, [expected], f'Found {found[0].name} instead of {expected[0].name}: {msg}')
|
|
|
|
|
|
@tagged('mail_tools', 'mail_init')
|
|
class TestMailUtils(MailCommon):
|
|
|
|
def test_migrate_icp_to_domain(self):
|
|
""" Test ICP to alias domain migration """
|
|
self.env["ir.config_parameter"].set_param("mail.catchall.domain", "test.migration.com")
|
|
self.env["ir.config_parameter"].set_param("mail.bounce.alias", "migrate+bounce")
|
|
self.env["ir.config_parameter"].set_param("mail.catchall.alias", "migrate+catchall")
|
|
self.env["ir.config_parameter"].set_param("mail.default.from", "migrate+default_from")
|
|
|
|
existing = self.env["mail.alias.domain"].search([('name', '=', 'test.migration.com')])
|
|
self.assertFalse(existing)
|
|
|
|
new = self.env["mail.alias.domain"]._migrate_icp_to_domain()
|
|
self.assertEqual(new.name, "test.migration.com")
|
|
self.assertEqual(new.bounce_alias, "migrate+bounce")
|
|
self.assertEqual(new.catchall_alias, "migrate+catchall")
|
|
self.assertEqual(new.default_from, "migrate+default_from")
|
|
|
|
again = self.env["mail.alias.domain"]._migrate_icp_to_domain()
|
|
self.assertEqual(again.name, "test.migration.com")
|
|
|
|
existing = self.env["mail.alias.domain"].search([('name', '=', 'test.migration.com')])
|
|
self.assertEqual(len(existing), 1, 'Should not migrate twice')
|