mirror of
https://github.com/bringout/oca-ocb-crm.git
synced 2026-04-24 01:12:04 +02:00
19.0 vanilla
This commit is contained in:
parent
dc68f80d3f
commit
7221b9ac46
610 changed files with 135477 additions and 161677 deletions
|
|
@ -4,8 +4,8 @@ from contextlib import contextmanager
|
|||
from unittest.mock import patch
|
||||
|
||||
from odoo import exceptions
|
||||
from odoo.addons.crm.models.crm_lead import Lead
|
||||
from odoo.addons.crm_iap_mine.models.crm_iap_lead_mining_request import CRMLeadMiningRequest
|
||||
from odoo.addons.crm.models.crm_lead import CrmLead
|
||||
from odoo.addons.crm_iap_mine.models.crm_iap_lead_mining_request import CrmIapLeadMiningRequest
|
||||
from odoo.addons.iap.tests.common import MockIAPEnrich
|
||||
from odoo.addons.iap.tools import iap_tools
|
||||
|
||||
|
|
@ -22,7 +22,7 @@ class MockIAPReveal(MockIAPEnrich):
|
|||
def mock_IAP_mine(self, mine, name_list=None, default_data=None, sim_error=None):
|
||||
self._new_leads = self.env['crm.lead'].sudo()
|
||||
self.mine = mine
|
||||
crm_lead_create_origin = Lead.create
|
||||
crm_lead_create_origin = CrmLead.create
|
||||
|
||||
def _crm_lead_create(model, *args, **kwargs):
|
||||
res = crm_lead_create_origin(model, *args, **kwargs)
|
||||
|
|
@ -31,10 +31,7 @@ class MockIAPReveal(MockIAPEnrich):
|
|||
|
||||
def _iap_contact_mining(params, timeout):
|
||||
self.assertMineCallParams(params)
|
||||
self.assertMinePayload(mine, params['data'])
|
||||
|
||||
if sim_error and sim_error == 'credit':
|
||||
raise iap_tools.InsufficientCreditError('InsufficientCreditError')
|
||||
if sim_error and sim_error == 'jsonrpc_exception':
|
||||
raise exceptions.AccessError(
|
||||
'The url that this service requested returned an error. Please contact the author of the app. The url it tried to contact was [STRIPPED]'
|
||||
|
|
@ -53,39 +50,21 @@ class MockIAPReveal(MockIAPEnrich):
|
|||
company_data = self._get_iap_company_data(base_name, service='mine')
|
||||
if default_data:
|
||||
company_data.update(default_data)
|
||||
iap_payload['company_data'] = company_data
|
||||
|
||||
if mine.search_type == 'people':
|
||||
people_data = self._get_iap_contact_data(base_name, service='mine')
|
||||
iap_payload['people_data'] = people_data
|
||||
|
||||
response.append(iap_payload)
|
||||
response.append(company_data)
|
||||
|
||||
return {
|
||||
'data': response,
|
||||
'credit_error': False
|
||||
'credit_error': sim_error == 'credit',
|
||||
}
|
||||
|
||||
with patch.object(CRMLeadMiningRequest, '_iap_contact_mining', side_effect=_iap_contact_mining), \
|
||||
patch.object(Lead, 'create', autospec=True, wraps=Lead, side_effect=_crm_lead_create):
|
||||
with patch.object(CrmIapLeadMiningRequest, '_iap_contact_mining', side_effect=_iap_contact_mining), \
|
||||
patch.object(CrmLead, 'create', autospec=True, wraps=CrmLead, side_effect=_crm_lead_create):
|
||||
yield
|
||||
|
||||
def _get_iap_company_data(self, base_name, service=None, add_values=None):
|
||||
company_data = super(MockIAPReveal, self)._get_iap_company_data(base_name, service=service, add_values=add_values)
|
||||
if service == 'mine':
|
||||
company_data['phone'] = company_data['phone_numbers'][0]
|
||||
company_data['sector'] = 'Sector Info'
|
||||
company_data = super()._get_iap_dnb_company_data(base_name, service=service, add_values=add_values)
|
||||
return company_data
|
||||
|
||||
def assertMineCallParams(self, params):
|
||||
self.assertTrue(bool(params['account_token']))
|
||||
self.assertTrue(bool(params['dbuuid']))
|
||||
|
||||
def assertMinePayload(self, mine, payload):
|
||||
if mine.search_type == 'people':
|
||||
self.assertEqual(payload['contact_number'], mine.contact_number)
|
||||
else:
|
||||
self.assertTrue('contact_number' not in payload)
|
||||
self.assertEqual(payload['countries'], mine.mapped('country_ids.code'))
|
||||
self.assertEqual(payload['lead_number'], mine.lead_number)
|
||||
self.assertEqual(payload['search_type'], mine.search_type)
|
||||
self.assertTrue(bool(params['db_uuid']))
|
||||
|
|
|
|||
|
|
@ -12,7 +12,7 @@ class TestLeadMine(TestCrmCommon, MockIAPReveal):
|
|||
@classmethod
|
||||
def setUpClass(cls):
|
||||
super(TestLeadMine, cls).setUpClass()
|
||||
cls.registry.enter_test_mode(cls.cr)
|
||||
cls.registry_enter_test_mode_cls()
|
||||
|
||||
cls.test_crm_tags = cls.env['crm.tag'].create([
|
||||
{'name': 'TestTag1'},
|
||||
|
|
@ -31,11 +31,6 @@ class TestLeadMine(TestCrmCommon, MockIAPReveal):
|
|||
'user_id': cls.user_sales_leads.id,
|
||||
})
|
||||
|
||||
@classmethod
|
||||
def tearDownClass(cls):
|
||||
cls.registry.leave_test_mode()
|
||||
super().tearDownClass()
|
||||
|
||||
@users('user_sales_manager')
|
||||
def test_mine_error_credit(self):
|
||||
mine_request = self.env['crm.iap.lead.mining.request'].browse(self.test_request.ids)
|
||||
|
|
@ -85,20 +80,17 @@ class TestLeadMine(TestCrmCommon, MockIAPReveal):
|
|||
self.assertEqual(lead.team_id, self.sales_team_1)
|
||||
self.assertEqual(lead.user_id, self.user_sales_leads)
|
||||
# iap
|
||||
self.assertEqual(lead.reveal_id, '123_ClearbitID_%s' % base_name, 'Ensure reveal_id is set to clearbit ID')
|
||||
# clearbit information
|
||||
self.assertEqual(lead.contact_name, 'Contact %s 0' % base_name)
|
||||
self.assertEqual(lead.reveal_id, '123456789', 'Ensure reveal_id is set to Duns')
|
||||
# DnB information
|
||||
self.assertFalse(lead.contact_name)
|
||||
self.assertEqual(lead.city, 'Mönchengladbach')
|
||||
self.assertEqual(lead.country_id, country_de)
|
||||
self.assertEqual(lead.email_from, 'test.contact.0@%s.example.com' % base_name,
|
||||
'Lead email should be the one from first contact if search_type people is given')
|
||||
self.assertEqual(lead.function, 'Doing stuff')
|
||||
self.assertFalse(lead.partner_id)
|
||||
self.assertEqual(lead.partner_name, '%s GmbH legal_name' % base_name)
|
||||
self.assertEqual(lead.phone, '+4930499193937')
|
||||
self.assertEqual(lead.partner_name, '%s GmbH' % base_name)
|
||||
self.assertEqual(lead.phone, '4930499193937')
|
||||
self.assertEqual(lead.state_id, state_de)
|
||||
self.assertEqual(lead.street, 'Mennrather Str. 123456')
|
||||
self.assertEqual(lead.website, 'https://www.%s.de' % base_name)
|
||||
self.assertEqual(lead.website, 'https://%s.de' % base_name)
|
||||
self.assertEqual(lead.zip, '41179')
|
||||
|
||||
@users('user_sales_manager')
|
||||
|
|
@ -126,17 +118,15 @@ class TestLeadMine(TestCrmCommon, MockIAPReveal):
|
|||
self.assertEqual(lead.team_id, self.sales_team_1)
|
||||
self.assertEqual(lead.user_id, self.user_sales_leads)
|
||||
# iap
|
||||
self.assertEqual(lead.reveal_id, '123_ClearbitID_%s' % base_name, 'Ensure reveal_id is set to clearbit ID')
|
||||
# clearbit information
|
||||
self.assertEqual(lead.reveal_id, '123456789', 'Ensure reveal_id is set to Duns')
|
||||
# DnB information
|
||||
self.assertFalse(lead.contact_name)
|
||||
self.assertEqual(lead.city, 'Mönchengladbach')
|
||||
self.assertEqual(lead.country_id, country_de)
|
||||
self.assertEqual(lead.email_from, 'info@%s.example.com' % base_name)
|
||||
self.assertFalse(lead.function)
|
||||
self.assertFalse(lead.partner_id)
|
||||
self.assertEqual(lead.partner_name, '%s GmbH legal_name' % base_name)
|
||||
self.assertEqual(lead.phone, '+4930499193937')
|
||||
self.assertEqual(lead.partner_name, '%s GmbH' % base_name)
|
||||
self.assertEqual(lead.phone, '4930499193937')
|
||||
self.assertEqual(lead.state_id, state_de)
|
||||
self.assertEqual(lead.street, 'Mennrather Str. 123456')
|
||||
self.assertEqual(lead.website, 'https://www.%s.de' % base_name)
|
||||
self.assertEqual(lead.website, 'https://%s.de' % base_name)
|
||||
self.assertEqual(lead.zip, '41179')
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue