2007-04-01 13:26:26 +08:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# Tests to prevent against recurrences of earlier bugs.
|
|
|
|
|
2007-09-20 07:40:47 +08:00
|
|
|
tests = r"""
|
2007-04-01 13:26:26 +08:00
|
|
|
It should be possible to re-use attribute dictionaries (#3810)
|
2008-07-19 09:22:26 +08:00
|
|
|
>>> from django.forms import *
|
2007-04-01 13:26:26 +08:00
|
|
|
>>> extra_attrs = {'class': 'special'}
|
|
|
|
>>> class TestForm(Form):
|
|
|
|
... f1 = CharField(max_length=10, widget=TextInput(attrs=extra_attrs))
|
|
|
|
... f2 = CharField(widget=TextInput(attrs=extra_attrs))
|
|
|
|
>>> TestForm(auto_id=False).as_p()
|
|
|
|
u'<p>F1: <input type="text" class="special" name="f1" maxlength="10" /></p>\n<p>F2: <input type="text" class="special" name="f2" /></p>'
|
2007-04-02 18:53:05 +08:00
|
|
|
|
2007-04-04 21:52:35 +08:00
|
|
|
#######################
|
|
|
|
# Tests for form i18n #
|
|
|
|
#######################
|
2007-04-02 18:53:05 +08:00
|
|
|
There were some problems with form translations in #3600
|
2007-04-04 21:52:35 +08:00
|
|
|
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
>>> from django.utils.translation import ugettext_lazy, activate, deactivate
|
2007-04-02 18:53:05 +08:00
|
|
|
>>> class SomeForm(Form):
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
... username = CharField(max_length=10, label=ugettext_lazy('Username'))
|
2007-04-02 18:53:05 +08:00
|
|
|
>>> f = SomeForm()
|
|
|
|
>>> print f.as_p()
|
|
|
|
<p><label for="id_username">Username:</label> <input id="id_username" type="text" name="username" maxlength="10" /></p>
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
|
|
|
|
Translations are done at rendering time, so multi-lingual apps can define forms
|
|
|
|
early and still send back the right translation.
|
|
|
|
|
2007-04-02 18:53:05 +08:00
|
|
|
>>> activate('de')
|
|
|
|
>>> print f.as_p()
|
|
|
|
<p><label for="id_username">Benutzername:</label> <input id="id_username" type="text" name="username" maxlength="10" /></p>
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
>>> activate('pl')
|
|
|
|
>>> f.as_p()
|
|
|
|
u'<p><label for="id_username">Nazwa u\u017cytkownika:</label> <input id="id_username" type="text" name="username" maxlength="10" /></p>'
|
2007-04-02 18:53:05 +08:00
|
|
|
>>> deactivate()
|
2007-04-04 21:52:35 +08:00
|
|
|
|
2008-08-31 19:39:06 +08:00
|
|
|
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()
|
|
|
|
<label for="id_field_1">field_1</label>
|
|
|
|
>>> print f['field_2'].label_tag()
|
|
|
|
<label for="field_2_id">field_2</label>
|
|
|
|
|
2007-04-04 21:52:35 +08:00
|
|
|
Unicode decoding problems...
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
>>> GENDERS = ((u'\xc5', u'En tied\xe4'), (u'\xf8', u'Mies'), (u'\xdf', u'Nainen'))
|
2007-04-04 21:52:35 +08:00
|
|
|
>>> class SomeForm(Form):
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
... somechoice = ChoiceField(choices=GENDERS, widget=RadioSelect(), label=u'\xc5\xf8\xdf')
|
2007-04-04 21:52:35 +08:00
|
|
|
>>> f = SomeForm()
|
|
|
|
>>> f.as_p()
|
2008-06-19 00:33:04 +08:00
|
|
|
u'<p><label for="id_somechoice_0">\xc5\xf8\xdf:</label> <ul>\n<li><label for="id_somechoice_0"><input type="radio" id="id_somechoice_0" value="\xc5" name="somechoice" /> En tied\xe4</label></li>\n<li><label for="id_somechoice_1"><input type="radio" id="id_somechoice_1" value="\xf8" name="somechoice" /> Mies</label></li>\n<li><label for="id_somechoice_2"><input type="radio" id="id_somechoice_2" value="\xdf" name="somechoice" /> Nainen</label></li>\n</ul></p>'
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
|
|
|
|
Testing choice validation with UTF-8 bytestrings as input (these are the
|
|
|
|
Russian abbreviations "мес." and "шт.".
|
|
|
|
|
|
|
|
>>> UNITS = (('\xd0\xbc\xd0\xb5\xd1\x81.', '\xd0\xbc\xd0\xb5\xd1\x81.'), ('\xd1\x88\xd1\x82.', '\xd1\x88\xd1\x82.'))
|
|
|
|
>>> f = ChoiceField(choices=UNITS)
|
|
|
|
>>> f.clean(u'\u0448\u0442.')
|
|
|
|
u'\u0448\u0442.'
|
|
|
|
>>> f.clean('\xd1\x88\xd1\x82.')
|
|
|
|
u'\u0448\u0442.'
|
|
|
|
|
|
|
|
Translated error messages used to be buggy.
|
|
|
|
>>> activate('ru')
|
|
|
|
>>> f = SomeForm({})
|
|
|
|
>>> f.as_p()
|
2008-06-19 00:33:04 +08:00
|
|
|
u'<ul class="errorlist"><li>\u041e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u043f\u043e\u043b\u0435.</li></ul>\n<p><label for="id_somechoice_0">\xc5\xf8\xdf:</label> <ul>\n<li><label for="id_somechoice_0"><input type="radio" id="id_somechoice_0" value="\xc5" name="somechoice" /> En tied\xe4</label></li>\n<li><label for="id_somechoice_1"><input type="radio" id="id_somechoice_1" value="\xf8" name="somechoice" /> Mies</label></li>\n<li><label for="id_somechoice_2"><input type="radio" id="id_somechoice_2" value="\xdf" name="somechoice" /> Nainen</label></li>\n</ul></p>'
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
>>> deactivate()
|
|
|
|
|
2007-09-15 18:57:03 +08:00
|
|
|
Deep copying translated text shouldn't raise an error
|
|
|
|
>>> from django.utils.translation import gettext_lazy
|
|
|
|
>>> class CopyForm(Form):
|
|
|
|
... degree = IntegerField(widget=Select(choices=((1, gettext_lazy('test')),)))
|
|
|
|
>>> f = CopyForm()
|
|
|
|
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
#######################
|
|
|
|
# Miscellaneous Tests #
|
|
|
|
#######################
|
|
|
|
|
2007-05-14 22:02:36 +08:00
|
|
|
There once was a problem with Form fields called "data". Let's make sure that
|
|
|
|
doesn't come back.
|
|
|
|
>>> class DataForm(Form):
|
|
|
|
... data = CharField(max_length=10)
|
|
|
|
>>> f = DataForm({'data': 'xyzzy'})
|
|
|
|
>>> f.is_valid()
|
|
|
|
True
|
2007-05-15 00:24:51 +08:00
|
|
|
>>> f.cleaned_data
|
2007-05-14 22:02:36 +08:00
|
|
|
{'data': u'xyzzy'}
|
2007-04-01 13:26:26 +08:00
|
|
|
"""
|