{
    "Selected_candidate": {
        "pr_number": 8362,
        "pr_title": "Fixed #28058 -- Restored empty BoundFields evaluating to True.",
        "pr_body": "https://code.djangoproject.com/ticket/28058",
        "issue_id": 28058,
        "issue_title": "Empty Select widget (no choices) evaluates to False",
        "issue_body": "Hey guys,\nI'm not sure I catched a bug, but I discovered a change between\nDjango==1.10.6\nand 1.11.\nWhen you initialize a form with a\nSelect\nwidget, and the select widget has no choices (basically an empty tuple), when evaluating the field with\nbool()\n, it will evaluate to\nFalse\n. This causes the\ndjango_widget_tweaks\nmodule not to render a widget when trying to modify it from within a template, as it uses a bool-like evaluation to check if anything is passed to the set_attr.\ncode to reproduce:\nfrom django import forms\n\nclass MyForm(forms.Form):\n    select = forms.ChoiceField(choices=())\n\nx = MyForm()\n\nfor item in x:\n    print(bool(item))\nIt will print\nTrue\nwith\nDjango==1.10.6\n, and\nFalse\nwith\nDjango==1.11\n.\nThe underlying problem is that\nlen()\nfor a Boundfield with no choices will return 0 in the newer version, whereas it returns 1 in the older version.\nthe template code that fails to render with\nDjango==1.11\n{{ widget|set_attr('style:width: 100%') }}\nLike I said, I'm not sure if this change is intended, nevertheless I reported it. Please let me know if this is intended, so I can let the creator of\ndjango_widget_tweaks\nknow.\nCheers",
        "issue_closed_at": "2017-04-17T07:49:12",
        "base_commit": "e5dce7b0fbd2965e524ce97114f501319ec2bb6f",
        "changes": [
            {
                "file": "django/forms/boundfield.py",
                "type": "function",
                "name": "subwidgets",
                "class_name": "BoundField",
                "code": "def subwidgets(self):\n        \"\"\"\n        Most widgets yield a single subwidget, but others like RadioSelect and\n        CheckboxSelectMultiple produce one subwidget for each choice.\n\n        This property is cached so that only one database query occurs when\n        rendering ModelChoiceFields.\n        \"\"\"\n        id_ = self.field.widget.attrs.get('id') or self.auto_id\n        attrs = {'id': id_} if id_ else {}\n        attrs = self.build_widget_attrs(attrs)\n        return list(\n            BoundWidget(self.field.widget, widget, self.form.renderer)\n            for widget in self.field.widget.subwidgets(self.html_name, self.value(), attrs=attrs)\n        )"
            }
        ]
    },
    "Justification": "Candidate E addresses a critical aspect of how attributes and evaluations are handled in Django forms, which is relevant to the CURRENT bug involving the failure of attributes expected from a function in a partial object. Both reports touch on the handling of objects and their attributes in Django, which means the insights from Candidate E about the evaluation of empty widgets could lend perspective on fixing the attribute error in the CURRENT bug. The patch similarity also adds to its relevance, as both required handling the behavior of their respective objects correctly within the Django framework."
}