Skip to content
Snippets Groups Projects
Commit c806f008 authored by dasa-odoo's avatar dasa-odoo
Browse files

[IMP] crm: improve _compute_meeting performance


We can use ._search() to make sure that permissions and ir.rules are applied. By making use of psql subqueries, we remove the need of costly python filtering afterwards, thus increasing performance.

Created test_meeting_count() to check that that the computing of meeting_count is done correctly.

closes odoo/odoo#88460

Signed-off-by: default avatarThibault Delavallee (tde) <tde@openerp.com>
parent 7830655e
Branches
Tags
No related merge requests found
......@@ -62,18 +62,19 @@ class Partner(models.Model):
def _compute_meeting(self):
if self.ids:
all_partners = self.with_context(active_test=False).search([('id', 'child_of', self.ids)])
event_id = self.env['calendar.event']._search([]) # ir.rules will be applied
subquery_string, subquery_params = event_id.select()
subquery = self.env.cr.mogrify(subquery_string, subquery_params).decode()
self.env.cr.execute("""
SELECT res_partner_id, calendar_event_id, count(1)
FROM calendar_event_res_partner_rel
WHERE res_partner_id IN %s
WHERE res_partner_id IN %s AND calendar_event_id IN ({})
GROUP BY res_partner_id, calendar_event_id
""", [tuple(all_partners.ids)])
meeting_data = self.env.cr.fetchall()
""".format(subquery), [tuple(all_partners.ids)])
# Keep only valid meeting data based on record rules of events
events = [row[1] for row in meeting_data]
events = self.env['calendar.event'].search([('id', 'in', events)]).ids
meeting_data = [m for m in meeting_data if m[1] in events]
meeting_data = self.env.cr.fetchall()
# Create a dict {partner_id: event_ids} and fill with events linked to the partner
meetings = {p.id: set() for p in all_partners}
......
......@@ -9,3 +9,4 @@ from . import test_crm_lead_merge
from . import test_crm_activity
from . import test_crm_ui
from . import test_crm_pls
from . import test_res_partner
# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo.tests.common import TransactionCase
from odoo.tests.common import new_test_user
class TestResPartner(TransactionCase):
def test_meeting_count(self):
test_user = new_test_user(self.env, login='test_user', groups='sales_team.group_sale_salesman')
Partner = self.env['res.partner'].with_user(test_user)
Event = self.env['calendar.event'].with_user(test_user)
# Partner hierarchy
# 1 5
# /|
# 2 3
# |
# 4
test_partner_1 = Partner.create({'name': 'test_partner_1'})
test_partner_2 = Partner.create({'name': 'test_partner_2', 'parent_id': test_partner_1.id})
test_partner_3 = Partner.create({'name': 'test_partner_3', 'parent_id': test_partner_1.id})
test_partner_4 = Partner.create({'name': 'test_partner_4', 'parent_id': test_partner_3.id})
test_partner_5 = Partner.create({'name': 'test_partner_5'})
Event.create({'name': 'event_1',
'partner_ids': [(6, 0, [test_partner_1.id,
test_partner_2.id,
test_partner_3.id,
test_partner_4.id])]})
Event.create({'name': 'event_2',
'partner_ids': [(6, 0, [test_partner_1.id,
test_partner_3.id])]})
Event.create({'name': 'event_2',
'partner_ids': [(6, 0, [test_partner_2.id,
test_partner_3.id])]})
Event.create({'name': 'event_3',
'partner_ids': [(6, 0, [test_partner_3.id,
test_partner_4.id])]})
Event.create({'name': 'event_4',
'partner_ids': [(6, 0, [test_partner_1.id])]})
Event.create({'name': 'event_5',
'partner_ids': [(6, 0, [test_partner_3.id])]})
Event.create({'name': 'event_6',
'partner_ids': [(6, 0, [test_partner_4.id])]})
Event.create({'name': 'event_7',
'partner_ids': [(6, 0, [test_partner_5.id])]})
Event.create({'name': 'event_8',
'partner_ids': [(6, 0, [test_partner_5.id])]})
#Test rule to see if ir.rules are applied
calendar_event_model_id = self.env['ir.model']._get('calendar.event').id
self.env['ir.rule'].create({'name': 'test_rule',
'model_id': calendar_event_model_id,
'domain_force': [('name', 'not in', ['event_9', 'event_10'])],
'perm_read': True,
'perm_create': False,
'perm_write': False})
Event.create({'name': 'event_9',
'partner_ids': [(6, 0, [test_partner_2.id,
test_partner_3.id])]})
Event.create({'name': 'event_10',
'partner_ids': [(6, 0, [test_partner_5.id])]})
self.assertEqual(test_partner_1.meeting_count, 7)
self.assertEqual(test_partner_2.meeting_count, 2)
self.assertEqual(test_partner_3.meeting_count, 6)
self.assertEqual(test_partner_4.meeting_count, 3)
self.assertEqual(test_partner_5.meeting_count, 2)
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment