mirror of https://github.com/django/django.git
Converted French localflavor doctests into unittests. We have always been at war with doctests. Thanks to Idan Gazit.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@14939 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
eb4b1ab1a0
commit
6127cf13cd
|
@ -1,117 +1,40 @@
|
||||||
# -*- coding: utf-8 -*-
|
from django.contrib.localflavor.fr.forms import (FRZipCodeField,
|
||||||
# Tests for the contrib/localflavor/ FR form fields.
|
FRPhoneNumberField, FRDepartmentSelect)
|
||||||
|
|
||||||
tests = r"""
|
from utils import LocalFlavorTestCase
|
||||||
# FRZipCodeField #############################################################
|
|
||||||
|
|
||||||
FRZipCodeField validates that the data is a valid FR zipcode.
|
|
||||||
>>> from django.contrib.localflavor.fr.forms import FRZipCodeField
|
|
||||||
>>> f = FRZipCodeField()
|
|
||||||
>>> f.clean('75001')
|
|
||||||
u'75001'
|
|
||||||
>>> f.clean('93200')
|
|
||||||
u'93200'
|
|
||||||
>>> f.clean('2A200')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'Enter a zip code in the format XXXXX.']
|
|
||||||
>>> f.clean('980001')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'Enter a zip code in the format XXXXX.']
|
|
||||||
>>> f.clean(None)
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'This field is required.']
|
|
||||||
>>> f.clean('')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'This field is required.']
|
|
||||||
|
|
||||||
>>> f = FRZipCodeField(required=False)
|
|
||||||
>>> f.clean('75001')
|
|
||||||
u'75001'
|
|
||||||
>>> f.clean('93200')
|
|
||||||
u'93200'
|
|
||||||
>>> f.clean('2A200')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'Enter a zip code in the format XXXXX.']
|
|
||||||
>>> f.clean('980001')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'Enter a zip code in the format XXXXX.']
|
|
||||||
>>> f.clean(None)
|
|
||||||
u''
|
|
||||||
>>> f.clean('')
|
|
||||||
u''
|
|
||||||
|
|
||||||
|
|
||||||
# FRPhoneNumberField ##########################################################
|
class FRLocalFlavorTests(LocalFlavorTestCase):
|
||||||
|
def test_FRZipCodeField(self):
|
||||||
|
error_format = [u'Enter a zip code in the format XXXXX.']
|
||||||
|
valid = {
|
||||||
|
'75001': '75001',
|
||||||
|
'93200': '93200',
|
||||||
|
}
|
||||||
|
invalid = {
|
||||||
|
'2A200': error_format,
|
||||||
|
'980001': error_format,
|
||||||
|
}
|
||||||
|
self.assertFieldOutput(FRZipCodeField, valid, invalid)
|
||||||
|
|
||||||
FRPhoneNumberField validates that the data is a valid french phone number.
|
def test_FRPhoneNumberField(self):
|
||||||
It's normalized to 0X XX XX XX XX format. Dots are valid too.
|
error_format = [u'Phone numbers must be in 0X XX XX XX XX format.']
|
||||||
>>> from django.contrib.localflavor.fr.forms import FRPhoneNumberField
|
valid = {
|
||||||
>>> f = FRPhoneNumberField()
|
'01 55 44 58 64': '01 55 44 58 64',
|
||||||
>>> f.clean('01 55 44 58 64')
|
'0155445864': '01 55 44 58 64',
|
||||||
u'01 55 44 58 64'
|
'01 5544 5864': '01 55 44 58 64',
|
||||||
>>> f.clean('0155445864')
|
'01 55.44.58.64': '01 55 44 58 64',
|
||||||
u'01 55 44 58 64'
|
'01.55.44.58.64': '01 55 44 58 64',
|
||||||
>>> f.clean('01 5544 5864')
|
}
|
||||||
u'01 55 44 58 64'
|
invalid = {
|
||||||
>>> f.clean('01 55.44.58.64')
|
'01,55,44,58,64': error_format,
|
||||||
u'01 55 44 58 64'
|
'555 015 544': error_format,
|
||||||
>>> f.clean('01.55.44.58.64')
|
}
|
||||||
u'01 55 44 58 64'
|
self.assertFieldOutput(FRPhoneNumberField, valid, invalid)
|
||||||
>>> f.clean('01,55,44,58,64')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'Phone numbers must be in 0X XX XX XX XX format.']
|
|
||||||
>>> f.clean('555 015 544')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'Phone numbers must be in 0X XX XX XX XX format.']
|
|
||||||
>>> f.clean(None)
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'This field is required.']
|
|
||||||
>>> f.clean('')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'This field is required.']
|
|
||||||
|
|
||||||
>>> f = FRPhoneNumberField(required=False)
|
def test_FRDepartmentSelect(self):
|
||||||
>>> f.clean('01 55 44 58 64')
|
f = FRDepartmentSelect()
|
||||||
u'01 55 44 58 64'
|
out = u'''<select name="dep">
|
||||||
>>> f.clean('0155445864')
|
|
||||||
u'01 55 44 58 64'
|
|
||||||
>>> f.clean('01 5544 5864')
|
|
||||||
u'01 55 44 58 64'
|
|
||||||
>>> f.clean('01 55.44.58.64')
|
|
||||||
u'01 55 44 58 64'
|
|
||||||
>>> f.clean('01.55.44.58.64')
|
|
||||||
u'01 55 44 58 64'
|
|
||||||
>>> f.clean('01,55,44,58,64')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'Phone numbers must be in 0X XX XX XX XX format.']
|
|
||||||
>>> f.clean('555 015 544')
|
|
||||||
Traceback (most recent call last):
|
|
||||||
...
|
|
||||||
ValidationError: [u'Phone numbers must be in 0X XX XX XX XX format.']
|
|
||||||
>>> f.clean(None)
|
|
||||||
u''
|
|
||||||
>>> f.clean('')
|
|
||||||
u''
|
|
||||||
|
|
||||||
# FRDepartmentSelect ###############################################################
|
|
||||||
|
|
||||||
FRDepartmentSelect is a Select widget that uses a list of french departments
|
|
||||||
including DOM TOM
|
|
||||||
>>> from django.contrib.localflavor.fr.forms import FRDepartmentSelect
|
|
||||||
>>> w = FRDepartmentSelect()
|
|
||||||
>>> print w.render('dep', 'Paris')
|
|
||||||
<select name="dep">
|
|
||||||
<option value="01">01 - Ain</option>
|
<option value="01">01 - Ain</option>
|
||||||
<option value="02">02 - Aisne</option>
|
<option value="02">02 - Aisne</option>
|
||||||
<option value="03">03 - Allier</option>
|
<option value="03">03 - Allier</option>
|
||||||
|
@ -218,5 +141,5 @@ including DOM TOM
|
||||||
<option value="986">986 - Wallis et Futuna</option>
|
<option value="986">986 - Wallis et Futuna</option>
|
||||||
<option value="987">987 - Polynesie Francaise</option>
|
<option value="987">987 - Polynesie Francaise</option>
|
||||||
<option value="988">988 - Nouvelle-Caledonie</option>
|
<option value="988">988 - Nouvelle-Caledonie</option>
|
||||||
</select>
|
</select>'''
|
||||||
"""
|
self.assertEqual(f.render('dep', 'Paris'), out)
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
from localflavor.cz import tests as localflavor_cz_tests
|
from localflavor.cz import tests as localflavor_cz_tests
|
||||||
from localflavor.fr import tests as localflavor_fr_tests
|
|
||||||
from localflavor.generic import tests as localflavor_generic_tests
|
from localflavor.generic import tests as localflavor_generic_tests
|
||||||
from localflavor.id import tests as localflavor_id_tests
|
from localflavor.id import tests as localflavor_id_tests
|
||||||
from localflavor.ie import tests as localflavor_ie_tests
|
from localflavor.ie import tests as localflavor_ie_tests
|
||||||
|
@ -30,13 +29,13 @@ from localflavor.cl import CLLocalFlavorTests
|
||||||
from localflavor.de import DELocalFlavorTests
|
from localflavor.de import DELocalFlavorTests
|
||||||
from localflavor.es import ESLocalFlavorTests
|
from localflavor.es import ESLocalFlavorTests
|
||||||
from localflavor.fi import FILocalFlavorTests
|
from localflavor.fi import FILocalFlavorTests
|
||||||
|
from localflavor.fr import FRLocalFlavorTests
|
||||||
from localflavor.il import ILLocalFlavorTests
|
from localflavor.il import ILLocalFlavorTests
|
||||||
from localflavor.tr import TRLocalFlavorTests
|
from localflavor.tr import TRLocalFlavorTests
|
||||||
|
|
||||||
|
|
||||||
__test__ = {
|
__test__ = {
|
||||||
'localflavor_cz_tests': localflavor_cz_tests,
|
'localflavor_cz_tests': localflavor_cz_tests,
|
||||||
'localflavor_fr_tests': localflavor_fr_tests,
|
|
||||||
'localflavor_generic_tests': localflavor_generic_tests,
|
'localflavor_generic_tests': localflavor_generic_tests,
|
||||||
'localflavor_id_tests': localflavor_id_tests,
|
'localflavor_id_tests': localflavor_id_tests,
|
||||||
'localflavor_ie_tests': localflavor_ie_tests,
|
'localflavor_ie_tests': localflavor_ie_tests,
|
||||||
|
|
|
@ -24,6 +24,7 @@ from regressiontests.forms.localflavortests import (
|
||||||
DELocalFlavorTests,
|
DELocalFlavorTests,
|
||||||
ESLocalFlavorTests,
|
ESLocalFlavorTests,
|
||||||
FILocalFlavorTests,
|
FILocalFlavorTests,
|
||||||
|
FRLocalFlavorTests,
|
||||||
ILLocalFlavorTests,
|
ILLocalFlavorTests,
|
||||||
TRLocalFlavorTests,
|
TRLocalFlavorTests,
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in New Issue