{
  "Selected_candidate": {
    "pr_number": 6263,
    "pr_title": "Fixed #26324 -- Fixed DurationField with fractional seconds on SQLite.",
    "pr_body": "https://code.djangoproject.com/ticket/26324\n",
    "issue_id": 26324,
    "issue_title": "DurationField stores certain values incorrectly in sqlite",
    "issue_body": "When encoding certain timedelta values in a\nDurationField\n, saving the object to a sqlite database and then reading it again,\nDurationField\nreturns None.\nclass\nFoo\n(\nmodels\n.\nModel\n):\nbar\n=\nmodels\n.\nDurationField\n()\nFoo\n.\nobjects\n.\ncreate\n(\nbar\n=\ntimedelta\n(\nseconds\n=\n2.05\n))\nFoo\n.\nobjects\n.\ncreate\n(\nbar\n=\ntimedelta\n(\nseconds\n=\n3.05\n))\nprint\nstr\n(\nFoo\n.\nobjects\n.\nall\n()[\n0\n]\n.\nbar\n)\n# 'None'\nprint\nstr\n(\nFoo\n.\nobjects\n.\nall\n()[\n1\n]\n.\nbar\n)\n# '3.05'\nI can reproduce this bug with Django 1.8.5 and 1.9.3 using sqlite as database backend. It does not occur with MySQL, so it seems to be related to how sqlite stores bigints. It renders\nDurationField\nessentially useless with sqlite.",
    "issue_closed_at": "2016-03-10T18:15:57",
    "base_commit": "85a4844f8a8e628b90fa30ba7074f162a2d188ef",
    "changes": [
      {
        "file": "django/db/models/fields/__init__.py",
        "type": "function",
        "name": "get_db_prep_value",
        "class_name": "UUIDField",
        "code": "def get_db_prep_value(self, value, connection, prepared=False):\n        if value is None:\n            return None\n        if not isinstance(value, uuid.UUID):\n            try:\n                value = uuid.UUID(value)\n            except AttributeError:\n                raise TypeError(self.error_messages['invalid'] % {'value': value})\n\n        if connection.features.has_native_uuid_field:\n            return value\n        return value.hex"
      }
    ]
  },
  "Justification": "Candidate A is the most helpful as it deals directly with the `DurationField` in Django, which is the component currently under examination in the CURRENT bug report. It addresses issues related to encoding and retrieving values, which relates to validating and formatting the duration string correctly. The structural similarity in the context of how `DurationField` operates, along with the relevance of the fix that pertains specifically to its handling in a database context, aligns very closely with the issues raised in the CURRENT bug. Furthermore, the fix provides insights into how to implement corrections that might affect the error messages regarding duration formatting.",
  "instance_id": "django__django-11049",
  "repo": "django/django",
  "created_at": "2019-03-03T09:56:16Z",
  "problem_statement": "Correct expected format in invalid DurationField error message\nDescription\n\t\nIf you enter a duration \"14:00\" into a duration field, it translates to \"00:14:00\" which is 14 minutes.\nThe current error message for invalid DurationField says that this should be the format of durations: \"[DD] [HH:[MM:]]ss[.uuuuuu]\". But according to the actual behaviour, it should be: \"[DD] [[HH:]MM:]ss[.uuuuuu]\", because seconds are mandatory, minutes are optional, and hours are optional if minutes are provided.\nThis seems to be a mistake in all Django versions that support the DurationField.\nAlso the duration fields could have a default help_text with the requested format, because the syntax is not self-explanatory.\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@@ -1587,7 +1587,7 @@ class DurationField(Field):\n     empty_strings_allowed = False\n     default_error_messages = {\n         'invalid': _(\"'%(value)s' value has an invalid format. It must be in \"\n-                     \"[DD] [HH:[MM:]]ss[.uuuuuu] format.\")\n+                     \"[DD] [[HH:]MM:]ss[.uuuuuu] format.\")\n     }\n     description = _(\"Duration\")\n \n"
}