summaryrefslogtreecommitdiff
path: root/tests/delete_regress
diff options
context:
space:
mode:
authorMariusz Felisiak <felisiak.mariusz@gmail.com>2021-04-27 09:53:27 +0200
committerMariusz Felisiak <felisiak.mariusz@gmail.com>2021-04-27 10:34:47 +0200
commit4074f38e1dcc93b859bbbfd6abd8441c3bca36b3 (patch)
tree29e45209e4d21b1e641b201ad953411449a1fb9b /tests/delete_regress
parent158eca4f93e492a6cc6f0240a0b6da3b7aa98ee6 (diff)
downloaddjango-4074f38e1dcc93b859bbbfd6abd8441c3bca36b3.tar.gz
Refs #32682 -- Fixed QuerySet.delete() crash on querysets with self-referential subqueries on MySQL.
Diffstat (limited to 'tests/delete_regress')
-rw-r--r--tests/delete_regress/models.py1
-rw-r--r--tests/delete_regress/tests.py14
2 files changed, 15 insertions, 0 deletions
diff --git a/tests/delete_regress/models.py b/tests/delete_regress/models.py
index 90eae1ba1c..e06da1288b 100644
--- a/tests/delete_regress/models.py
+++ b/tests/delete_regress/models.py
@@ -24,6 +24,7 @@ class Person(models.Model):
class Book(models.Model):
pagecount = models.IntegerField()
+ owner = models.ForeignKey('Child', models.CASCADE, null=True)
class Toy(models.Model):
diff --git a/tests/delete_regress/tests.py b/tests/delete_regress/tests.py
index 97a7d6ba02..fe758eab74 100644
--- a/tests/delete_regress/tests.py
+++ b/tests/delete_regress/tests.py
@@ -1,6 +1,7 @@
import datetime
from django.db import connection, models, transaction
+from django.db.models import Exists, OuterRef
from django.test import (
SimpleTestCase, TestCase, TransactionTestCase, skipUnlessDBFeature,
)
@@ -355,6 +356,19 @@ class DeleteTests(TestCase):
self.assertEqual(researcher2.primary_contact, contact2)
self.assertIsNone(researcher2.secondary_contact)
+ def test_self_reference_with_through_m2m_at_second_level(self):
+ toy = Toy.objects.create(name='Paints')
+ child = Child.objects.create(name='Juan')
+ Book.objects.create(pagecount=500, owner=child)
+ PlayedWith.objects.create(child=child, toy=toy, date=datetime.date.today())
+ Book.objects.filter(Exists(
+ Book.objects.filter(
+ pk=OuterRef('pk'),
+ owner__toys=toy.pk,
+ ),
+ )).delete()
+ self.assertIs(Book.objects.exists(), False)
+
class DeleteDistinct(SimpleTestCase):
def test_disallowed_delete_distinct(self):