diff --git a/django/forms/forms.py b/django/forms/forms.py index 753ee254bc..7d1254c5ea 100644 --- a/django/forms/forms.py +++ b/django/forms/forms.py @@ -374,7 +374,7 @@ class BoundField(StrAndUnicode): id_ = widget.attrs.get('id') or self.auto_id if id_: attrs = attrs and flatatt(attrs) or '' - contents = '' % (widget.id_for_label(id_), attrs, contents) + contents = u'' % (widget.id_for_label(id_), attrs, unicode(contents)) return mark_safe(contents) def _is_hidden(self): diff --git a/tests/regressiontests/forms/regressions.py b/tests/regressiontests/forms/regressions.py index 87390d3cd1..5e32cd397d 100644 --- a/tests/regressiontests/forms/regressions.py +++ b/tests/regressiontests/forms/regressions.py @@ -34,6 +34,16 @@ early and still send back the right translation. u'

' >>> deactivate() +There was some problems with form translations in #5216 +>>> class SomeForm(Form): +... field_1 = CharField(max_length=10, label=ugettext_lazy('field_1')) +... field_2 = CharField(max_length=10, label=ugettext_lazy('field_2'), widget=TextInput(attrs={'id': 'field_2_id'})) +>>> f = SomeForm() +>>> print f['field_1'].label_tag() + +>>> print f['field_2'].label_tag() + + Unicode decoding problems... >>> GENDERS = ((u'\xc5', u'En tied\xe4'), (u'\xf8', u'Mies'), (u'\xdf', u'Nainen')) >>> class SomeForm(Form):