{
  "Selected_candidate": {
    "pr_number": 750,
    "pr_title": "Method \"save\" in BaseModelFormSet is marked as alters_data",
    "pr_body": "Fixes #17663\n",
    "issue_id": 17663,
    "issue_title": "Method \"save\" in BaseModelFormSet is not marked as alters_data",
    "issue_body": "",
    "issue_closed_at": "2013-02-23T06:12:21",
    "base_commit": "6000600cc5ef6f56cb8076034295b1cea144f569",
    "changes": [
      {
        "file": "django/forms/models.py",
        "type": "function",
        "name": "save_m2m",
        "class_name": "BaseModelFormSet",
        "code": "def save_m2m():\n                for form in self.saved_forms:\n                    form.save_m2m()"
      }
    ]
  },
  "Justification": "Candidate C is particularly useful because it directly relates to the functionality of forms in Django. The CURRENT bug revolves around ensuring that the maximum length of choices aligns with their actual size, which affects how forms handle data submission. Given that the fix for Candidate C involved marking the 'save' method in BaseModelFormSet as alters_data, it implies ensuring data integrity in forms, which is aligned with preventing issues like excessively long inputs in fields. The shared focus on the form submission process makes this candidate the most relevant for debugging the CURRENT bug.",
  "instance_id": "django__django-11742",
  "repo": "django/django",
  "created_at": "2019-09-04T08:30:14Z",
  "problem_statement": "Add check to ensure max_length fits longest choice.\nDescription\n\t\nThere is currently no check to ensure that Field.max_length is large enough to fit the longest value in Field.choices.\nThis would be very helpful as often this mistake is not noticed until an attempt is made to save a record with those values that are too long.\n",
  "patch": "diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py\n--- a/django/db/models/fields/__init__.py\n+++ b/django/db/models/fields/__init__.py\n@@ -257,6 +257,7 @@ def is_value(value, accept_promise=True):\n                 )\n             ]\n \n+        choice_max_length = 0\n         # Expect [group_name, [value, display]]\n         for choices_group in self.choices:\n             try:\n@@ -270,16 +271,32 @@ def is_value(value, accept_promise=True):\n                     for value, human_name in group_choices\n                 ):\n                     break\n+                if self.max_length is not None and group_choices:\n+                    choice_max_length = max(\n+                        choice_max_length,\n+                        *(len(value) for value, _ in group_choices if isinstance(value, str)),\n+                    )\n             except (TypeError, ValueError):\n                 # No groups, choices in the form [value, display]\n                 value, human_name = group_name, group_choices\n                 if not is_value(value) or not is_value(human_name):\n                     break\n+                if self.max_length is not None and isinstance(value, str):\n+                    choice_max_length = max(choice_max_length, len(value))\n \n             # Special case: choices=['ab']\n             if isinstance(choices_group, str):\n                 break\n         else:\n+            if self.max_length is not None and choice_max_length > self.max_length:\n+                return [\n+                    checks.Error(\n+                        \"'max_length' is too small to fit the longest value \"\n+                        \"in 'choices' (%d characters).\" % choice_max_length,\n+                        obj=self,\n+                        id='fields.E009',\n+                    ),\n+                ]\n             return []\n \n         return [\n"
}