mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #33547 -- Fixed error when rendering invalid inlines with readonly fields in admin.
Regression in de95c82667.
Thanks David Glenck for the report.
			
			
This commit is contained in:
		| @@ -138,7 +138,11 @@ def cell_count(inline_admin_form): | ||||
|         # Count all visible fields. | ||||
|         for line in fieldset: | ||||
|             for field in line: | ||||
|                 if not field.field.is_hidden: | ||||
|                 try: | ||||
|                     is_hidden = field.field.is_hidden | ||||
|                 except AttributeError: | ||||
|                     is_hidden = field.field["is_hidden"] | ||||
|                 if not is_hidden: | ||||
|                     count += 1 | ||||
|     if inline_admin_form.formset.can_delete: | ||||
|         # Delete checkbox | ||||
|   | ||||
| @@ -15,3 +15,7 @@ Bugfixes | ||||
| * Prevented, following a regression in Django 4.0.1, :djadmin:`makemigrations` | ||||
|   from generating infinite migrations for a model with ``ManyToManyField`` to | ||||
|   a lowercased swappable model such as ``'auth.user'`` (:ticket:`33515`). | ||||
|  | ||||
| * Fixed a regression in Django 4.0 that caused a crash when rendering invalid | ||||
|   inlines with :attr:`~django.contrib.admin.ModelAdmin.readonly_fields` in the | ||||
|   admin (:ticket:`33547`). | ||||
|   | ||||
| @@ -5,6 +5,7 @@ import random | ||||
|  | ||||
| from django.contrib.contenttypes.fields import GenericForeignKey | ||||
| from django.contrib.contenttypes.models import ContentType | ||||
| from django.core.exceptions import ValidationError | ||||
| from django.db import models | ||||
|  | ||||
|  | ||||
| @@ -204,6 +205,9 @@ class Question(models.Model): | ||||
|     text = models.CharField(max_length=40) | ||||
|     poll = models.ForeignKey(Poll, models.CASCADE) | ||||
|  | ||||
|     def clean(self): | ||||
|         raise ValidationError("Always invalid model.") | ||||
|  | ||||
|  | ||||
| class Novel(models.Model): | ||||
|     name = models.CharField(max_length=40) | ||||
|   | ||||
| @@ -241,6 +241,22 @@ class TestInline(TestDataMixin, TestCase): | ||||
|         # column cells | ||||
|         self.assertContains(response, "<p>Callable in QuestionInline</p>") | ||||
|  | ||||
|     def test_model_error_inline_with_readonly_field(self): | ||||
|         poll = Poll.objects.create(name="Test poll") | ||||
|         data = { | ||||
|             "question_set-TOTAL_FORMS": 1, | ||||
|             "question_set-INITIAL_FORMS": 0, | ||||
|             "question_set-MAX_NUM_FORMS": 0, | ||||
|             "_save": "Save", | ||||
|             "question_set-0-text": "Question", | ||||
|             "question_set-0-poll": poll.pk, | ||||
|         } | ||||
|         response = self.client.post( | ||||
|             reverse("admin:admin_inlines_poll_change", args=(poll.pk,)), | ||||
|             data, | ||||
|         ) | ||||
|         self.assertContains(response, "Always invalid model.") | ||||
|  | ||||
|     def test_help_text(self): | ||||
|         """ | ||||
|         The inlines' model field help texts are displayed when using both the | ||||
|   | ||||
		Reference in New Issue
	
	Block a user