Hi Anand I would save *don't* use Django signal. Signals are hard to test and don't know when they will be executed.
Suggestions - If post_save function does some work like updating external service which can take data, use rq or celery. - You can override django save. class MyModel(BaseClass): def save(self, **kwargs) # set all attributes # call super class save # call function here - blocking call. On Tue, Jul 8, 2014 at 1:13 PM, Anand Reddy Pandikunta < anand21na...@gmail.com> wrote: > Hi, > > *models.py* > > *def my_func(sender, instance, created, **kwargs):* > * # do something* > * instance.status = 'task completed'* > * instance.save()* > > *class MyModel(models.Model):* > * status = models.CharField(max_length=100, blank=True)* > * # some code* > > *signals.post_save.connect(my_func, sender=MyModel)* > > > I am using post_save signal to connect to a function. > > If a new instance of model is saved, post_save signal connects to my_func. > Once the function is executed, I am updating status of the model. > This is again sending post_save signal which is leading to infinite loop. > > I want to execute my_func only once and update status many times. > Does any one know how to do this? > > > -- > - Anand Reddy Pandikunta > www.avilpage.com > www.quotes160.com > _______________________________________________ > BangPypers mailing list > BangPypers@python.org > https://mail.python.org/mailman/listinfo/bangpypers > -- *Thanks & Regardskracekumar"Talk is cheap, show me the code" -- Linus Torvaldshttp://kracekumar.com <http://kracekumar.com>* _______________________________________________ BangPypers mailing list BangPypers@python.org https://mail.python.org/mailman/listinfo/bangpypers