{
  "id": "django__django-12308",
  "question": "JSONField are not properly displayed in admin when they are readonly.\nDescription\n\t\nJSONField values are displayed as dict when readonly in the admin.\nFor example, {\"foo\": \"bar\"} would be displayed as {'foo': 'bar'}, which is not valid JSON.\nI believe the fix would be to add a special case in django.contrib.admin.utils.display_for_field to call the prepare_value of the JSONField (not calling json.dumps directly to take care of the InvalidJSONInput case).\n",
  "answer": "{\"task_id\": \"5a8c753f-20ea-4883-970e-9c723e5733f4\", \"workflow_run_id\": \"e8a2c471-a222-4ee8-8bf6-e18f26789f9e\", \"data\": {\"id\": \"e8a2c471-a222-4ee8-8bf6-e18f26789f9e\", \"workflow_id\": \"bc5a1a30-852f-4fd7-98f0-8fca2f23c564\", \"status\": \"succeeded\", \"outputs\": {\"ranked_patches\": \"```json\\n{\\n  \\\"ranked_patches\\\": [\\n    {\\n      \\\"patch_id\\\": 1,\\n      \\\"patch\\\": \\\"diff --git a/django/contrib/admin/utils.py b/django/contrib/admin/utils.py\\\\nindex abcdef1..1234567 100644\\\\n--- a/django/contrib/admin/utils.py\\\\n+++ b/django/contrib/admin/utils.py\\\\n@@ -153,6 +153,8 @@ def display_for_field(value, field, empty_value_display):\\\\n     from django.db.models import DateTimeField, DateField, TimeField\\\\n     from django.db.models.fields.json import JSONField\\\\n \\\\n+    if isinstance(field, JSONField) and field.read_only:\\\\n+        return field.prepare_value(value)\\\\n \\\\n     if isinstance(field, (DateField, DateTimeField, TimeField)):\\\\n         return formats.localize_input(value) or empty_value_display\\\\n\\\",\\n      \\\"rank\\\": 1,\\n      \\\"score\\\": 0.95,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.9,\\n        \\\"code_quality\\\": 0.95,\\n        \\\"risk_level\\\": 0.1,\\n        \\\"best_practices\\\": 0.9,\\n        \\\"test_coverage\\\": 0.85\\n      },\\n      \\\"reasoning\\\": \\\"This patch correctly addresses the issue by using the field's prepare_value method, which is likely to handle JSON serialization correctly and consistently with Django's internal mechanisms. It minimizes the risk of introducing new bugs by leveraging existing functionality.\\\",\\n      \\\"recommendation\\\": \\\"Highly recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 3,\\n      \\\"patch\\\": \\\"diff --git a/django/contrib/admin/utils.py b/django/contrib/admin/utils.py\\\\nindex abcdef1..abcdef2 100644\\\\n--- a/django/contrib/admin/utils.py\\\\n+++ b/django/contrib/admin/utils.py\\\\n@@ -153,6 +153,14 @@ def display_for_field(value, field, empty_value_display):\\\\n     from django.db.models import DateTimeField, DateField, TimeField\\\\n     from django.db.models.fields.json import JSONField\\\\n \\\\n+    if isinstance(field, JSONField):\\\\n+        try:\\\\n+            if field.read_only:\\\\n+                import json\\\\n+                return json.dumps(value, ensure_ascii=False)\\\\n+        except (TypeError, ValueError):\\\\n+            return empty_value_display\\\\n \\\\n     if isinstance(field, (DateField, DateTimeField, TimeField)):\\\\n         return formats.localize_input(value) or empty_value_display\\\\n\\\",\\n      \\\"rank\\\": 2,\\n      \\\"score\\\": 0.85,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.85,\\n        \\\"code_quality\\\": 0.8,\\n        \\\"risk_level\\\": 0.2,\\n        \\\"best_practices\\\": 0.85,\\n        \\\"test_coverage\\\": 0.8\\n      },\\n      \\\"reasoning\\\": \\\"This patch attempts to handle potential errors during JSON serialization, which is a good practice. However, it uses json.dumps directly, which might not handle all edge cases as well as Django's internal methods. The try-except block adds robustness but also slightly increases complexity.\\\",\\n      \\\"recommendation\\\": \\\"Recommended with caution\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 2,\\n      \\\"patch\\\": \\\"diff --git a/django/contrib/admin/utils.py b/django/contrib/admin/utils.py\\\\nindex abcdef1..7654321 100644\\\\n--- a/django/contrib/admin/utils.py\\\\n+++ b/django/contrib/admin/utils.py\\\\n@@ -153,6 +153,7 @@ def display_for_field(value, field, empty_value_display):\\\\n     from django.db.models import DateTimeField, DateField, TimeField\\\\n     from django.db.models.fields.json import JSONField\\\\n \\\\n+    if isinstance(field, JSONField) and getattr(field, 'read_only', False):\\\\n+        import json\\\\n+        return json.dumps(value, ensure_ascii=False)\\\\n \\\\n     if isinstance(field, (DateField, DateTimeField, TimeField)):\\\\n         return formats.localize_input(value) or empty_value_display\\\\n\\\",\\n      \\\"rank\\\": 3,\\n      \\\"score\\\": 0.75,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.75,\\n        \\\"code_quality\\\": 0.75,\\n        \\\"risk_level\\\": 0.3,\\n        \\\"best_practices\\\": 0.75,\\n        \\\"test_coverage\\\": 0.75\\n      },\\n      \\\"reasoning\\\": \\\"This patch uses json.dumps directly without handling potential exceptions, which could lead to unhandled errors if the JSON is not serializable. It also doesn't leverage Django's internal methods, which might lead to inconsistencies with other parts of the framework.\\\",\\n      \\\"recommendation\\\": \\\"Not recommended\\\"\\n    }\\n  ],\\n  \\\"evaluation_summary\\\": \\\"Patch 1 is the most robust and aligns well with Django's internal mechanisms, making it the best choice. Patch 3 adds error handling but increases complexity and doesn't use Django's internal methods. Patch 2 is the least recommended due to its direct use of json.dumps without error handling.\\\"\\n}\\n```\", \"generated_tests\": \"{\\n  \\\"reproduction_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_issue_with_readonly_JSONField\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_issue_with_readonly_JSONField():\\\\n    # Simulate a readonly JSONField value {'foo': 'bar'} displayed incorrectly\\\\n    readonly_json_value = {'foo': 'bar'}\\\\n    readonly_json_field = JSONField(read_only=True)\\\\n    displayed_value = display_for_field(readonly_json_value, readonly_json_field, '-')\\\\n    assert displayed_value == \\\\\\\"{'foo': 'bar'}\\\\\\\", 'Incorrect display of readonly JSONField value'\\\",\\n    \\\"description\\\": \\\"This test reproduces the issue where readonly JSONField values are displayed incorrectly in the admin\\\",\\n    \\\"expected_behavior\\\": \\\"The test should fail before the patch is applied and pass after\\\"\\n    }\\n  ],\\n  \\\"validation_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_patch1_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch1_validation():\\\\n    # Test the patch 1 implementation for displaying readonly JSONFields\\\\n    readonly_json_value = {'foo': 'bar'}\\\\n    readonly_json_field = JSONField(read_only=True)\\\\n    displayed_value = display_for_field(readonly_json_value, readonly_json_field, '-')\\\\n    assert displayed_value == '{\\\\\\\"foo\\\\\\\": \\\\\\\"bar\\\\\\\"}', 'Patch 1 failed to correct the display of readonly JSONField value'\\\",\\n    \\\"description\\\": \\\"This test validates that Patch 1 correctly handles the display of readonly JSONFields\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_patch2_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch2_validation():\\\\n    # Test the patch 2 implementation for displaying readonly JSONFields\\\\n    readonly_json_value = {'foo': 'bar'}\\\\n    readonly_json_field = JSONField(read_only=True)\\\\n    displayed_value = display_for_field(readonly_json_value, readonly_json_field, '-')\\\\n    assert displayed_value == '{\\\\\\\"foo\\\\\\\": \\\\\\\"bar\\\\\\\"}', 'Patch 2 failed to correct the display of readonly JSONField value'\\\",\\n    \\\"description\\\": \\\"This test validates that Patch 2 correctly handles the display of readonly JSONFields\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_patch3_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch3_validation():\\\\n    # Test the patch 3 implementation for displaying readonly JSONFields\\\\n    readonly_json_value = {'foo': 'bar'}\\\\n    readonly_json_field = JSONField(read_only=True)\\\\n    displayed_value = display_for_field(readonly_json_value, readonly_json_field, '-')\\\\n    assert displayed_value == '{\\\\\\\"foo\\\\\\\": \\\\\\\"bar\\\\\\\"}', 'Patch 3 failed to correct the display of readonly JSONField value'\\\",\\n    \\\"description\\\": \\\"This test validates that Patch 3 correctly handles the display of readonly JSONFields\\\"\\n    }\\n  ],\\n  \\\"test_summary\\\": \\\"Generated tests for reproducing the issue with readonly JSONField values displayed incorrectly in the admin, and validation tests for each patch to ensure they fix the problem\\\"\\n}\"}, \"error\": \"\", \"elapsed_time\": 158.123334, \"total_tokens\": 11836, \"total_steps\": 9, \"created_at\": 1753291259, \"finished_at\": 1753291417}}"
}