Improve test to ensure that post_delete was actually called

This commit is contained in:
David Cramer 2013-01-14 13:18:24 -08:00
parent abbb88886b
commit a7ed09d13d
1 changed files with 7 additions and 0 deletions

View File

@ -230,8 +230,12 @@ class DeletionTests(TestCase):
models.signals.post_delete.disconnect(log_pre_delete) models.signals.post_delete.disconnect(log_pre_delete)
def test_relational_post_delete_signals_happen_before_parent_object(self): def test_relational_post_delete_signals_happen_before_parent_object(self):
deletions = []
def log_post_delete(instance, **kwargs): def log_post_delete(instance, **kwargs):
self.assertTrue(R.objects.filter(pk=instance.r_id)) self.assertTrue(R.objects.filter(pk=instance.r_id))
self.assertEquals(type(instance), S)
deletions.append(instance.id)
r = R.objects.create(pk=1) r = R.objects.create(pk=1)
S.objects.create(pk=1, r=r) S.objects.create(pk=1, r=r)
@ -243,6 +247,9 @@ class DeletionTests(TestCase):
finally: finally:
models.signals.post_delete.disconnect(log_post_delete) models.signals.post_delete.disconnect(log_post_delete)
self.assertEquals(len(deletions), 1)
self.assertEquals(deletions[0], 1)
@skipUnlessDBFeature("can_defer_constraint_checks") @skipUnlessDBFeature("can_defer_constraint_checks")
def test_can_defer_constraint_checks(self): def test_can_defer_constraint_checks(self):
u = User.objects.create( u = User.objects.create(