mirror of
https://github.com/django/django.git
synced 2025-10-31 09:41:08 +00:00
Fixed #18491 -- deleting a proxy doesn't show warning about cascade deletes
This commit is contained in:
@@ -2,6 +2,7 @@ from __future__ import absolute_import, unicode_literals
|
||||
import copy
|
||||
|
||||
from django.conf import settings
|
||||
from django.contrib import admin
|
||||
from django.contrib.contenttypes.models import ContentType
|
||||
from django.core import management
|
||||
from django.core.exceptions import FieldError
|
||||
@@ -14,7 +15,7 @@ from django.test import TestCase
|
||||
from .models import (MyPerson, Person, StatusPerson, LowerStatusPerson,
|
||||
MyPersonProxy, Abstract, OtherPerson, User, UserProxy, UserProxyProxy,
|
||||
Country, State, StateProxy, TrackerUser, BaseUser, Bug, ProxyTrackerUser,
|
||||
Improvement, ProxyProxyBug, ProxyBug, ProxyImprovement)
|
||||
Improvement, ProxyProxyBug, ProxyBug, ProxyImprovement, Issue)
|
||||
|
||||
|
||||
class ProxyModelTests(TestCase):
|
||||
@@ -360,3 +361,28 @@ class ProxyModelTests(TestCase):
|
||||
management.call_command('loaddata', 'mypeople.json', verbosity=0, commit=False)
|
||||
p = MyPerson.objects.get(pk=100)
|
||||
self.assertEqual(p.name, 'Elvis Presley')
|
||||
|
||||
|
||||
class ProxyModelAdminTests(TestCase):
|
||||
def setUp(self):
|
||||
management.call_command('loaddata', 'myhorses.json', verbosity=0,
|
||||
commit=False)
|
||||
|
||||
def tearDown(self):
|
||||
TrackerUser.objects.all().delete()
|
||||
Issue.objects.all().delete()
|
||||
|
||||
def test_cascade_delete_proxy_model_admin_warning(self):
|
||||
"""
|
||||
Test if admin gives warning about cascade deleting models referenced
|
||||
to concrete model by deleting proxy object.
|
||||
"""
|
||||
tracker_user = TrackerUser.objects.all()[0]
|
||||
base_user = BaseUser.objects.all()[0]
|
||||
issue = Issue.objects.all()[0]
|
||||
with self.assertNumQueries(7):
|
||||
collector = admin.util.NestedObjects('default')
|
||||
collector.collect(ProxyTrackerUser.objects.all())
|
||||
self.assertTrue(tracker_user in collector.edges.get(None, ()))
|
||||
self.assertTrue(base_user in collector.edges.get(None, ()))
|
||||
self.assertTrue(issue in collector.edges.get(tracker_user, ()))
|
||||
|
||||
Reference in New Issue
Block a user