Fixed #25883 -- Fixed admin deletion page summary counts for related objects.

This commit is contained in:
Sergey Fedoseev 2015-12-10 12:06:01 +05:00 committed by Tim Graham
parent a44dc200d0
commit 8ab58b8052
4 changed files with 11 additions and 5 deletions

View File

@ -163,8 +163,9 @@ def get_deleted_objects(objs, opts, user, admin_site, using):
to_delete = collector.nested(format_callback) to_delete = collector.nested(format_callback)
protected = [format_callback(obj) for obj in collector.protected] protected = [format_callback(obj) for obj in collector.protected]
model_count = {model._meta.verbose_name_plural: len(objs) for model, objs in collector.model_objs.items()}
return to_delete, collector.model_count, perms_needed, protected return to_delete, model_count, perms_needed, protected
class NestedObjects(Collector): class NestedObjects(Collector):
@ -172,7 +173,7 @@ class NestedObjects(Collector):
super(NestedObjects, self).__init__(*args, **kwargs) super(NestedObjects, self).__init__(*args, **kwargs)
self.edges = {} # {from_instance: [to_instances]} self.edges = {} # {from_instance: [to_instances]}
self.protected = set() self.protected = set()
self.model_count = defaultdict(int) self.model_objs = defaultdict(set)
def add_edge(self, source, target): def add_edge(self, source, target):
self.edges.setdefault(source, []).append(target) self.edges.setdefault(source, []).append(target)
@ -187,7 +188,7 @@ class NestedObjects(Collector):
self.add_edge(getattr(obj, related_name), obj) self.add_edge(getattr(obj, related_name), obj)
else: else:
self.add_edge(None, obj) self.add_edge(None, obj)
self.model_count[obj._meta.verbose_name_plural] += 1 self.model_objs[obj._meta.model].add(obj)
try: try:
return super(NestedObjects, self).collect(objs, source_attr=source_attr, **kwargs) return super(NestedObjects, self).collect(objs, source_attr=source_attr, **kwargs)
except models.ProtectedError as e: except models.ProtectedError as e:

View File

@ -26,3 +26,6 @@ Bugfixes
* Fixed missing ``varchar/text_pattern_ops`` index on ``CharField`` and * Fixed missing ``varchar/text_pattern_ops`` index on ``CharField`` and
``TextField`` respectively when using ``AlterField`` on PostgreSQL ``TextField`` respectively when using ``AlterField`` on PostgreSQL
(:ticket:`25412`). (:ticket:`25412`).
* Fixed admin's delete confirmation page's summary counts of related objects
(:ticket:`25883`).

View File

@ -40,6 +40,7 @@ class Article(models.Model):
content = models.TextField() content = models.TextField()
date = models.DateTimeField() date = models.DateTimeField()
section = models.ForeignKey(Section, models.CASCADE, null=True, blank=True) section = models.ForeignKey(Section, models.CASCADE, null=True, blank=True)
another_section = models.ForeignKey(Section, models.CASCADE, null=True, blank=True, related_name='+')
sub_section = models.ForeignKey(Section, models.SET_NULL, null=True, blank=True, related_name='+') sub_section = models.ForeignKey(Section, models.SET_NULL, null=True, blank=True, related_name='+')
def __str__(self): def __str__(self):

View File

@ -1292,7 +1292,8 @@ class AdminViewPermissionsTest(TestCase):
) )
cls.s1 = Section.objects.create(name='Test section') cls.s1 = Section.objects.create(name='Test section')
cls.a1 = Article.objects.create( cls.a1 = Article.objects.create(
content='<p>Middle content</p>', date=datetime.datetime(2008, 3, 18, 11, 54, 58), section=cls.s1 content='<p>Middle content</p>', date=datetime.datetime(2008, 3, 18, 11, 54, 58), section=cls.s1,
another_section=cls.s1,
) )
cls.a2 = Article.objects.create( cls.a2 = Article.objects.create(
content='<p>Oldest content</p>', date=datetime.datetime(2000, 3, 18, 11, 54, 58), section=cls.s1 content='<p>Oldest content</p>', date=datetime.datetime(2000, 3, 18, 11, 54, 58), section=cls.s1
@ -3203,7 +3204,7 @@ class AdminActionsTest(TestCase):
self.assertIsInstance(confirmation, TemplateResponse) self.assertIsInstance(confirmation, TemplateResponse)
self.assertContains(confirmation, "Are you sure you want to delete the selected subscribers?") self.assertContains(confirmation, "Are you sure you want to delete the selected subscribers?")
self.assertContains(confirmation, "<h2>Summary</h2>") self.assertContains(confirmation, "<h2>Summary</h2>")
self.assertContains(confirmation, "<li>Subscribers: 3</li>") self.assertContains(confirmation, "<li>Subscribers: 2</li>")
self.assertContains(confirmation, "<li>External subscribers: 1</li>") self.assertContains(confirmation, "<li>External subscribers: 1</li>")
self.assertContains(confirmation, ACTION_CHECKBOX_NAME, count=2) self.assertContains(confirmation, ACTION_CHECKBOX_NAME, count=2)
self.client.post(reverse('admin:admin_views_subscriber_changelist'), delete_confirmation_data) self.client.post(reverse('admin:admin_views_subscriber_changelist'), delete_confirmation_data)