summaryrefslogtreecommitdiff
path: root/tests/delete_regress
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2018-01-13 12:23:48 +0100
committerTim Graham <timograham@gmail.com>2018-01-13 10:31:00 -0500
commit9a621edf624a4eb1f1645fca628a9e432f0de776 (patch)
treef486088aff2eea286b3f8ab9bfa3d658c07d0977 /tests/delete_regress
parentcea5fe94c6bb1b61e791f1375c246566c950b3e3 (diff)
downloaddjango-9a621edf624a4eb1f1645fca628a9e432f0de776.tar.gz
Fixed #29016 -- Fixed incorrect foreign key nullification on related instance deletion.
Diffstat (limited to 'tests/delete_regress')
-rw-r--r--tests/delete_regress/models.py2
-rw-r--r--tests/delete_regress/tests.py28
2 files changed, 28 insertions, 2 deletions
diff --git a/tests/delete_regress/models.py b/tests/delete_regress/models.py
index f0145de65b..90eae1ba1c 100644
--- a/tests/delete_regress/models.py
+++ b/tests/delete_regress/models.py
@@ -56,6 +56,8 @@ class Email(Contact):
class Researcher(models.Model):
contacts = models.ManyToManyField(Contact, related_name="research_contacts")
+ primary_contact = models.ForeignKey(Contact, models.SET_NULL, null=True, related_name='primary_contacts')
+ secondary_contact = models.ForeignKey(Contact, models.SET_NULL, null=True, related_name='secondary_contacts')
class Food(models.Model):
diff --git a/tests/delete_regress/tests.py b/tests/delete_regress/tests.py
index 7f913257ab..a8b1cb0386 100644
--- a/tests/delete_regress/tests.py
+++ b/tests/delete_regress/tests.py
@@ -4,7 +4,7 @@ from django.db import connection, models, transaction
from django.test import TestCase, TransactionTestCase, skipUnlessDBFeature
from .models import (
- Award, AwardNote, Book, Child, Eaten, Email, File, Food, FooFile,
+ Award, AwardNote, Book, Child, Contact, Eaten, Email, File, Food, FooFile,
FooFileProxy, FooImage, FooPhoto, House, Image, Item, Location, Login,
OrderedPerson, OrgUnit, Person, Photo, PlayedWith, PlayedWithNote, Policy,
Researcher, Toy, Version,
@@ -334,7 +334,7 @@ class Ticket19102Tests(TestCase):
self.assertTrue(Login.objects.filter(pk=self.l2.pk).exists())
-class OrderedDeleteTests(TestCase):
+class DeleteTests(TestCase):
def test_meta_ordered_delete(self):
# When a subquery is performed by deletion code, the subquery must be
# cleared of all ordering. There was a but that caused _meta ordering
@@ -344,3 +344,27 @@ class OrderedDeleteTests(TestCase):
OrderedPerson.objects.create(name='Bob', lives_in=h)
OrderedPerson.objects.filter(lives_in__address='Foo').delete()
self.assertEqual(OrderedPerson.objects.count(), 0)
+
+ def test_foreign_key_delete_nullifies_correct_columns(self):
+ """
+ With a model (Researcher) that has two foreign keys pointing to the
+ same model (Contact), deleting an instance of the target model
+ (contact1) nullifies the correct fields of Researcher.
+ """
+ contact1 = Contact.objects.create(label='Contact 1')
+ contact2 = Contact.objects.create(label='Contact 2')
+ researcher1 = Researcher.objects.create(
+ primary_contact=contact1,
+ secondary_contact=contact2,
+ )
+ researcher2 = Researcher.objects.create(
+ primary_contact=contact2,
+ secondary_contact=contact1,
+ )
+ contact1.delete()
+ researcher1.refresh_from_db()
+ researcher2.refresh_from_db()
+ self.assertIsNone(researcher1.primary_contact)
+ self.assertEqual(researcher1.secondary_contact, contact2)
+ self.assertEqual(researcher2.primary_contact, contact2)
+ self.assertIsNone(researcher2.secondary_contact)