diff --git a/addons/mail/mail_message.py b/addons/mail/mail_message.py index 7e09fa4eb81..ac68a4bfd7f 100644 --- a/addons/mail/mail_message.py +++ b/addons/mail/mail_message.py @@ -791,6 +791,13 @@ class mail_message(osv.Model): message_id = tools.generate_tracking_message_id('private') return message_id + @api.multi + def _invalidate_documents(self): + """ Invalidate the cache of the documents followed by ``self``. """ + for record in self: + if record.res_id: + self.env[record.model].invalidate_cache(ids=[record.res_id]) + def create(self, cr, uid, values, context=None): context = dict(context or {}) default_starred = context.pop('default_starred', False) @@ -805,6 +812,7 @@ class mail_message(osv.Model): values['record_name'] = self._get_record_name(cr, uid, values, context=context) newid = super(mail_message, self).create(cr, uid, values, context) + self.browse(cr, uid, newid, context)._invalidate_documents() self._notify(cr, uid, newid, context=context, force_send=context.get('mail_notify_force_send', True), @@ -826,6 +834,14 @@ class mail_message(osv.Model): res = super(mail_message, self).read(cr, uid, ids, fields=fields, context=context, load=load) return res + @api.multi + def write(self, vals): + if 'model' in vals or 'res_id' in vals: + self._invalidate_documents() + res = super(mail_message, self).write(vals) + self._invalidate_documents() + return res + def unlink(self, cr, uid, ids, context=None): # cascade-delete attachments that are directly attached to the message (should only happen # for mail.messages that act as parent for a standalone mail.mail record). @@ -837,6 +853,7 @@ class mail_message(osv.Model): attachments_to_delete.append(attach.id) if attachments_to_delete: self.pool.get('ir.attachment').unlink(cr, uid, attachments_to_delete, context=context) + self.browse(cr, uid, ids, context)._invalidate_documents() return super(mail_message, self).unlink(cr, uid, ids, context=context) #------------------------------------------------------ diff --git a/addons/mail/tests/test_mail_message.py b/addons/mail/tests/test_mail_message.py index e6e78fe9254..8cad520ce8b 100644 --- a/addons/mail/tests/test_mail_message.py +++ b/addons/mail/tests/test_mail_message.py @@ -445,3 +445,8 @@ class TestMailMessage(TestMail): {'subject': 'Subject', 'body': 'Body text'}, {'default_composition_mode': 'comment', 'default_parent_id': pigs_msg_id}) mail_compose.send_mail(cr, user_raoul_id, [compose_id]) + + def test_60_cache_invalidation(self): + msg_cnt = len(self.group_pigs.message_ids) + self.group_pigs.message_post(body='Hi!', subject='test') + self.assertEqual(len(self.group_pigs.message_ids), msg_cnt + 1)