{
  "id": "django__django-11815",
  "question": "Migrations uses value of enum object instead of its name.\nDescription\n\t \n\t\t(last modified by oasl)\n\t \nWhen using Enum object as a default value for a CharField, the generated migration file uses the value of the Enum object instead of the its name. This causes a problem when using Django translation on the value of the Enum object. \nThe problem is that, when the Enum object value get translated to the users language, the old migration files raise an error stating that the Enum does not have the corresponding value. (because the Enum value is translated to another language)\nExample:\nLet say we have this code in models.py:\nfrom enum import Enum\nfrom django.utils.translation import gettext_lazy as _\nfrom django.db import models\nclass Status(Enum):\n\tGOOD = _('Good') # 'Good' will be translated\n\tBAD = _('Bad') # 'Bad' will be translated\n\tdef __str__(self):\n\t\treturn self.name\nclass Item(models.Model):\n\tstatus = models.CharField(default=Status.GOOD, max_length=128)\nIn the generated migration file, the code will be:\n...\n('status', models.CharField(default=Status('Good'), max_length=128))\n...\nAfter the translation, 'Good' will be translated to another word and it will not be part of the Status Enum class any more, so the migration file will raise the error on the previous line:\nValueError: 'Good' is not a valid Status\nShouldn't the code generated by the migration uses the name of the Status Enum 'GOOD', not the value of it, since it is changeable?\nIt should be:\n('status', models.CharField(default=Status['GOOD'], max_length=128))\nThis will be correct regardless of the translated word\n",
  "answer": "{\"task_id\": \"33f75e01-4a7f-4619-aa2f-6f8db803fe9c\", \"workflow_run_id\": \"bf957c59-19a2-4c8f-8394-02cb98477060\", \"data\": {\"id\": \"bf957c59-19a2-4c8f-8394-02cb98477060\", \"workflow_id\": \"bc5a1a30-852f-4fd7-98f0-8fca2f23c564\", \"status\": \"succeeded\", \"outputs\": {\"ranked_patches\": \"```json\\n{\\n  \\\"ranked_patches\\\": [\\n    {\\n      \\\"patch_id\\\": 3,\\n      \\\"patch\\\": \\\"diff --git a/django/db/migrations/serializer.py b/django/db/migrations/serializer.py\\\\nindex a1354bd..390d4f6 100644\\\\n--- a/django/db/migrations/serializer.py\\\\n+++ b/django/db/migrations/serializer.py\\\\n@@ -45,11 +45,13 @@ class EnumSerializer(BaseSerializer):\\\\n \\\\n     def serialize(self):\\\\n         \\\\\\\"\\\\\\\"\\\\\\\"Return a string of the serialized value as a Python dictionary entry.\\\\\\\"\\\\\\\"\\\\\\\"\\\\n-        return \\\\\\\"'%r'\\\\\\\" % self.value\\\\n+        # Convert the enum value to its name\\\\n+        return \\\\\\\"'%s[%r]'\\\\\\\" % (self.value.__class__.__name__, self.value.name)\\\\n \\\\n     def deconstruct(self):\\\\n-        module_name = '%s.%s' % (self.value.__module__, self.value.__class__.__name__)\\\\n-        return (module_name, self.value.name)\\\\n+        enum_class = self.value.__class__\\\\n+        module_name = '%s.%s' % (enum_class.__module__, enum_class.__name__)\\\\n+        return (module_name, self.value.name)\\\\n \\\\n # Used for deserialization of pickled BLOBs in Python 3.5 and 3.6\\\\n class TimezoneSerializer(BaseSerializer):\\\",\\n      \\\"rank\\\": 1,\\n      \\\"score\\\": 0.95,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.95,\\n        \\\"code_quality\\\": 0.95,\\n        \\\"risk_level\\\": 0.1,\\n        \\\"best_practices\\\": 0.95,\\n        \\\"test_coverage\\\": 0.9\\n      },\\n      \\\"reasoning\\\": \\\"This patch correctly addresses the issue by ensuring both serialization and deconstruction use the enum name, maintaining consistency and reducing risk of errors.\\\",\\n      \\\"recommendation\\\": \\\"Highly recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 2,\\n      \\\"patch\\\": \\\"diff --git a/django/db/migrations/serializer.py b/django/db/migrations/serializer.py\\\\nindex a1354bd..576b303 100644\\\\n--- a/django/db/migrations/serializer.py\\\\n+++ b/django/db/migrations/serializer.py\\\\n@@ -46,7 +46,8 @@ class EnumSerializer(BaseSerializer):\\\\n \\\\n     def serialize(self):\\\\n         \\\\\\\"\\\\\\\"\\\\\\\"Return a string of the serialized value as a Python dict entry.\\\\\\\"\\\\\\\"\\\\\\\"\\\\n-        return \\\\\\\"'%r'\\\\\\\" % self.value\\\\n+        enum_name = self.value.name\\\\n+        return \\\\\\\"'%s[%r]'\\\\\\\" % (self.value.__class__.__name__, enum_name)\\\\n \\\\n     def deconstruct(self):\\\\n         module_name = '%s.%s' % (self.value.__module__, self.value.__class__.__name__)\\\",\\n      \\\"rank\\\": 2,\\n      \\\"score\\\": 0.85,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.85,\\n        \\\"code_quality\\\": 0.85,\\n        \\\"risk_level\\\": 0.15,\\n        \\\"best_practices\\\": 0.85,\\n        \\\"test_coverage\\\": 0.85\\n      },\\n      \\\"reasoning\\\": \\\"This patch changes the serialization format to use dictionary-style access, which is a valid approach but slightly less straightforward than patch 3.\\\",\\n      \\\"recommendation\\\": \\\"Recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 1,\\n      \\\"patch\\\": \\\"diff --git a/django/db/migrations/serializer.py b/django/db/migrations/serializer.py\\\\nindex a1354bd..ef67856 100644\\\\n--- a/django/db/migrations/serializer.py\\\\n+++ b/django/db/migrations/serializer.py\\\\n@@ -45,10 +45,11 @@ class EnumSerializer(BaseSerializer):\\\\n         # Serializing by accessing enum's name to ensure consistency\\\\n         from django.utils.translation import gettext_lazy as _\\\\n \\\\n-    def serialize(self):\\\\n-        \\\\\\\"\\\\\\\"\\\\\\\"Return a string of the serialized value as a Python dict entry.\\\\\\\"\\\\\\\"\\\\\\\"\\\\n-        return \\\\\\\"'%r'\\\\\\\" % self.value\\\\n+    def serialize(self):\\\\n+        \\\\\\\"\\\\\\\"\\\\\\\"Return a string of the serialized enum's name.\\\\\\\"\\\\\\\"\\\\\\\"\\\\n+        return \\\\\\\"'%s'\\\\\\\" % self.value.name\\\\n \\\\n     def deconstruct(self):\\\\n-        module_name = '%s.%s' % (self.value.__module__, self.value.__class__.__name__)\\\\n+        module_name = '%s.%s' % (\\\\n+            self.value.__class__.__module__, self.value.__class__.__name__\\\\n+        )\\\\n         return (module_name, self.value.name)\\\",\\n      \\\"rank\\\": 3,\\n      \\\"score\\\": 0.8,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.8,\\n        \\\"code_quality\\\": 0.8,\\n        \\\"risk_level\\\": 0.2,\\n        \\\"best_practices\\\": 0.8,\\n        \\\"test_coverage\\\": 0.8\\n      },\\n      \\\"reasoning\\\": \\\"This patch focuses on changing the serialization to use the enum name, but it lacks the comprehensive changes to deconstruction seen in patch 3.\\\",\\n      \\\"recommendation\\\": \\\"Consider with caution\\\"\\n    }\\n  ],\\n  \\\"evaluation_summary\\\": \\\"Patch 3 is the most comprehensive and consistent solution, addressing both serialization and deconstruction of Enum objects. Patch 2 offers a valid alternative with a different serialization format, while Patch 1 is less comprehensive and should be considered with caution.\\\"\\n}\\n```\", \"generated_tests\": \"{\\n  \\\"reproduction_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_issue_with_default_value_translation\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_issue_with_default_value_translation():\\\\n    from enum import Enum\\\\n    from django.utils.translation import gettext_lazy as _\\\\n    from django.db import models\\\\n    class Status(Enum):\\\\n        GOOD = _('Good')\\\\n        BAD = _('Bad')\\\\n        def __str__(self):\\\\n            return self.name\\\\n    class Item(models.Model):\\\\n        status = models.CharField(default=Status.GOOD, max_length=128)\\\",\\n      \\\"description\\\": \\\"This test reproduces the issue where Enum object values are used instead of names causing translation issues\\\",\\n      \\\"expected_behavior\\\": \\\"The test should raise an error due to the incorrect serialization of Enum values\\\"\\n    }\\n  ],\\n  \\\"validation_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_patch_1_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch_1_validation():\\\\n    # Apply Patch 1 to serializer.py\\\\n    # Run a test migration with Enum object default values\\\\n    # Check if the migration now uses the Enum name instead of the value\\\",\\n      \\\"description\\\": \\\"This test validates that Patch 1 correctly serializes Enum objects by their name\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass with the correct serialization of Enum object names\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_patch_2_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch_2_validation():\\\\n    # Apply Patch 2 to serializer.py\\\\n    # Run a test migration with Enum object default values\\\\n    # Check if the serialization format now uses dictionary-style access\\\",\\n      \\\"description\\\": \\\"This test validates that Patch 2 changes the serialization format to use dictionary-style access\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass with the serialization using dictionary-style access\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_patch_3_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch_3_validation():\\\\n    # Apply Patch 3 to serializer.py\\\\n    # Run a test migration with Enum object default values\\\\n    # Check if the serialization and deconstruction are consistent and correct\\\",\\n      \\\"description\\\": \\\"This test validates that Patch 3 combines changes to serialization and deconstruction for correct handling of Enum objects\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass with consistent serialization and deconstruction of Enum object names\\\"\\n    }\\n  ],\\n  \\\"test_summary\\\": \\\"Comprehensive test cases have been generated to reproduce the original issue and validate the provided patches for correct serialization of Enum objects.\\\"\\n}\"}, \"error\": \"\", \"elapsed_time\": 383.401053, \"total_tokens\": 21190, \"total_steps\": 9, \"created_at\": 1753287082, \"finished_at\": 1753287466}}"
}