Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Django signal m2m_changed not triggered

I recently started to use signals in my Django project (v. 1.3) and they all work fine except that I just can't figure out why the m2m_changed signal never gets triggered on my model. The Section instance is edited by adding/deleting PageChild inline instances on an django admin form.

I tried to register the callback function either way as described in the documentation, but don't get any result.

Excerpt from my models.py

from django.db import models
from django.db.models.signals import m2m_changed


class Section(models.Model):
    name = models.CharField(unique = True, max_length = 100)
    pages = models.ManyToManyField(Page, through = 'PageChild')

class PageChild(models.Model):
    section = models.ForeignKey(Section)
    page = models.ForeignKey(Page, limit_choices_to = Q(is_template = False, is_background = False))


@receiver(m2m_changed, sender = Section.pages.through)
def m2m(sender, **kwargs):
    print "m2m changed!"

m2m_changed.connect(m2m, sender = Section.pages.through, dispatch_uid = 'foo', weak = False)

Am I missing something obvious?

like image 464
user543424 Avatar asked Jun 24 '11 05:06

user543424


3 Answers

This is an open bug: https://code.djangoproject.com/ticket/16073

I wasted hours on it this week.

like image 97
jblaine Avatar answered Nov 03 '22 13:11

jblaine


You are connecting it twice, once with m2m_changed.connect and the other time with receiver decorator.

like image 3
vijay shanker Avatar answered Nov 03 '22 14:11

vijay shanker


Not sure if it will help, but the following is working for me:

class Flow(models.Model):
    datalist = models.ManyToManyField(Data)

from django.db.models.signals import post_save, pre_delete, m2m_changed

def handle_flow(sender, instance, *args, **kwargs):
    logger.debug("Signal catched !")

m2m_changed.connect(handle_flow, sender=Flow.datalist.through)
like image 2
Stéphane Avatar answered Nov 03 '22 12:11

Stéphane