From 8f6a7a0e9e7c5404af6520ae606927e32415eb00 Mon Sep 17 00:00:00 2001 From: Hugo Cachitas Date: Fri, 2 Apr 2021 12:59:15 +0100 Subject: [PATCH] Fixed #32594 -- Doc'd and tested that Signal.disconnect() with lazy references returns None. --- docs/topics/signals.txt | 4 +++- tests/signals/tests.py | 43 +++++++++++++++++++++++++++++++++++------ 2 files changed, 40 insertions(+), 7 deletions(-) diff --git a/docs/topics/signals.txt b/docs/topics/signals.txt index b76a000b34e..1c7d35aca15 100644 --- a/docs/topics/signals.txt +++ b/docs/topics/signals.txt @@ -277,7 +277,9 @@ Disconnecting signals To disconnect a receiver from a signal, call :meth:`Signal.disconnect`. The arguments are as described in :meth:`.Signal.connect`. The method returns -``True`` if a receiver was disconnected and ``False`` if not. +``True`` if a receiver was disconnected and ``False`` if not. When ``sender`` +is passed as a lazy reference to ``.``, this method always +returns ``None``. The ``receiver`` argument indicates the registered receiver to disconnect. It may be ``None`` if ``dispatch_uid`` is used to identify the receiver. diff --git a/tests/signals/tests.py b/tests/signals/tests.py index ee4661c93fb..c4c692ea3ed 100644 --- a/tests/signals/tests.py +++ b/tests/signals/tests.py @@ -351,20 +351,51 @@ class LazyModelRefTests(BaseSignalSetup, SimpleTestCase): signals.post_init.disconnect(self.receiver, sender=Created) @isolate_apps('signals', kwarg_name='apps') - def test_disconnect(self, apps): + def test_disconnect_registered_model(self, apps): + received = [] + + def receiver(**kwargs): + received.append(kwargs) + + class Created(models.Model): + pass + + signals.post_init.connect(receiver, sender='signals.Created', apps=apps) + try: + self.assertIsNone( + signals.post_init.disconnect(receiver, sender='signals.Created', apps=apps) + ) + self.assertIsNone( + signals.post_init.disconnect(receiver, sender='signals.Created', apps=apps) + ) + Created() + self.assertEqual(received, []) + finally: + signals.post_init.disconnect(receiver, sender='signals.Created') + + @isolate_apps('signals', kwarg_name='apps') + def test_disconnect_unregistered_model(self, apps): received = [] def receiver(**kwargs): received.append(kwargs) signals.post_init.connect(receiver, sender='signals.Created', apps=apps) - signals.post_init.disconnect(receiver, sender='signals.Created', apps=apps) + try: + self.assertIsNone( + signals.post_init.disconnect(receiver, sender='signals.Created', apps=apps) + ) + self.assertIsNone( + signals.post_init.disconnect(receiver, sender='signals.Created', apps=apps) + ) - class Created(models.Model): - pass + class Created(models.Model): + pass - Created() - self.assertEqual(received, []) + Created() + self.assertEqual(received, []) + finally: + signals.post_init.disconnect(receiver, sender='signals.Created') def test_register_model_class_senders_immediately(self): """