Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Fixed #15838 -- Promoted assertFieldOutput to a general test utility.…

… Thanks to Ramiro Morales for the patch.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@16653 bcc190cf-cafb-0310-a4f2-bffc1f526a37
  • Loading branch information...
commit 2664fa189614a4dbbfed5cb683148707ab568f47 1 parent 46ef298
@freakboy3742 freakboy3742 authored
Showing with 167 additions and 161 deletions.
  1. +54 −4 django/test/testcases.py
  2. +21 −0 docs/topics/testing.txt
  3. +1 −11 tests/regressiontests/forms/localflavor/__init__.py
  4. +2 −2 tests/regressiontests/forms/localflavor/ar.py
  5. +2 −2 tests/regressiontests/forms/localflavor/at.py
  6. +2 −2 tests/regressiontests/forms/localflavor/au.py
  7. +2 −2 tests/regressiontests/forms/localflavor/be.py
  8. +2 −2 tests/regressiontests/forms/localflavor/br.py
  9. +2 −2 tests/regressiontests/forms/localflavor/ca.py
  10. +2 −2 tests/regressiontests/forms/localflavor/ch.py
  11. +2 −2 tests/regressiontests/forms/localflavor/cl.py
  12. +2 −2 tests/regressiontests/forms/localflavor/cn.py
  13. +2 −2 tests/regressiontests/forms/localflavor/co.py
  14. +2 −2 tests/regressiontests/forms/localflavor/cz.py
  15. +2 −2 tests/regressiontests/forms/localflavor/de.py
  16. +2 −2 tests/regressiontests/forms/localflavor/ec.py
  17. +2 −2 tests/regressiontests/forms/localflavor/es.py
  18. +2 −2 tests/regressiontests/forms/localflavor/fi.py
  19. +2 −2 tests/regressiontests/forms/localflavor/fr.py
  20. +2 −2 tests/regressiontests/forms/localflavor/gb.py
  21. +2 −2 tests/regressiontests/forms/localflavor/generic.py
  22. +2 −2 tests/regressiontests/forms/localflavor/hr.py
  23. +2 −2 tests/regressiontests/forms/localflavor/id.py
  24. +2 −2 tests/regressiontests/forms/localflavor/ie.py
  25. +2 −2 tests/regressiontests/forms/localflavor/il.py
  26. +2 −2 tests/regressiontests/forms/localflavor/in_.py
  27. +2 −2 tests/regressiontests/forms/localflavor/is_.py
  28. +2 −2 tests/regressiontests/forms/localflavor/it.py
  29. +2 −2 tests/regressiontests/forms/localflavor/jp.py
  30. +2 −2 tests/regressiontests/forms/localflavor/kw.py
  31. +2 −2 tests/regressiontests/forms/localflavor/mk.py
  32. +2 −2 tests/regressiontests/forms/localflavor/mx.py
  33. +2 −2 tests/regressiontests/forms/localflavor/nl.py
  34. +2 −2 tests/regressiontests/forms/localflavor/pl.py
  35. +2 −2 tests/regressiontests/forms/localflavor/pt.py
  36. +2 −2 tests/regressiontests/forms/localflavor/py.py
  37. +2 −2 tests/regressiontests/forms/localflavor/ro.py
  38. +2 −2 tests/regressiontests/forms/localflavor/ru.py
  39. +2 −2 tests/regressiontests/forms/localflavor/se.py
  40. +2 −2 tests/regressiontests/forms/localflavor/sk.py
  41. +2 −2 tests/regressiontests/forms/localflavor/us.py
  42. +0 −64 tests/regressiontests/forms/localflavor/utils.py
  43. +2 −2 tests/regressiontests/forms/localflavor/uy.py
  44. +2 −2 tests/regressiontests/forms/localflavor/za.py
  45. +0 −1  tests/regressiontests/forms/localflavortests.py
  46. +0 −1  tests/regressiontests/forms/tests/__init__.py
  47. +11 −0 tests/regressiontests/test_utils/tests.py
View
58 django/test/testcases.py
@@ -8,11 +8,14 @@
from django.conf import settings
from django.core import mail
+from django.core.exceptions import ValidationError
from django.core.management import call_command
from django.core.signals import request_started
from django.core.urlresolvers import clear_url_caches
+from django.core.validators import EMPTY_VALUES
from django.db import (transaction, connection, connections, DEFAULT_DB_ALIAS,
reset_queries)
+from django.forms.fields import CharField
from django.http import QueryDict
from django.test import _doctest as doctest
from django.test.client import Client
@@ -271,6 +274,53 @@ def assertRaisesMessage(self, expected_exception, expected_message,
return self.assertRaisesRegexp(expected_exception,
re.escape(expected_message), callable_obj, *args, **kwargs)
+ def assertFieldOutput(self, fieldclass, valid, invalid, field_args=None,
+ field_kwargs=None, empty_value=u''):
+ """
+ Asserts that a form field behaves correctly with various inputs.
+
+ Args:
+ fieldclass: the class of the field to be tested.
+ valid: a dictionary mapping valid inputs to their expected
+ cleaned values.
+ invalid: a dictionary mapping invalid inputs to one or more
+ raised error messages.
+ field_args: the args passed to instantiate the field
+ field_kwargs: the kwargs passed to instantiate the field
+ empty_value: the expected clean output for inputs in EMPTY_VALUES
+
+ """
+ if field_args is None:
+ field_args = []
+ if field_kwargs is None:
+ field_kwargs = {}
+ required = fieldclass(*field_args, **field_kwargs)
+ optional = fieldclass(*field_args, **dict(field_kwargs, required=False))
+ # test valid inputs
+ for input, output in valid.items():
+ self.assertEqual(required.clean(input), output)
+ self.assertEqual(optional.clean(input), output)
+ # test invalid inputs
+ for input, errors in invalid.items():
+ with self.assertRaises(ValidationError) as context_manager:
+ required.clean(input)
+ self.assertEqual(context_manager.exception.messages, errors)
+
+ with self.assertRaises(ValidationError) as context_manager:
+ optional.clean(input)
+ self.assertEqual(context_manager.exception.messages, errors)
+ # test required inputs
+ error_required = [u'This field is required.']
+ for e in EMPTY_VALUES:
+ with self.assertRaises(ValidationError) as context_manager:
+ required.clean(e)
+ self.assertEqual(context_manager.exception.messages, error_required)
+ self.assertEqual(optional.clean(e), empty_value)
+ # test that max_length and min_length are always accepted
+ if issubclass(fieldclass, CharField):
+ field_kwargs.update({'min_length':2, 'max_length':20})
+ self.assertTrue(isinstance(fieldclass(*field_args, **field_kwargs), fieldclass))
+
class TransactionTestCase(SimpleTestCase):
# The class we'll use for the test client self.client.
# Can be overridden in derived classes.
@@ -356,8 +406,8 @@ def _post_teardown(self):
# be created with the wrong time).
# To make sure this doesn't happen, get a clean connection at the
# start of every test.
- for connection in connections.all():
- connection.close()
+ for conn in connections.all():
+ conn.close()
def _fixture_teardown(self):
pass
@@ -552,9 +602,9 @@ def assertQuerysetEqual(self, qs, values, transform=repr):
def assertNumQueries(self, num, func=None, *args, **kwargs):
using = kwargs.pop("using", DEFAULT_DB_ALIAS)
- connection = connections[using]
+ conn = connections[using]
- context = _AssertNumQueriesContext(self, num, connection)
+ context = _AssertNumQueriesContext(self, num, conn)
if func is None:
return context
View
21 docs/topics/testing.txt
@@ -1178,6 +1178,7 @@ basic functionality like:
* Saving and restoring the Python warning machinery state.
* Checking that a callable :meth:`raises a certain exeception <TestCase.assertRaisesMessage>`.
+ * :meth:`Testing form field rendering <assertFieldOutput>`.
If you need any of the other more complex and heavyweight Django-specific
features like:
@@ -1523,6 +1524,26 @@ your test suite.
failure. Similar to unittest's ``assertRaisesRegexp`` with the difference
that ``expected_message`` isn't a regular expression.
+.. method:: assertFieldOutput(self, fieldclass, valid, invalid, field_args=None, field_kwargs=None, empty_value=u'')
+
+ Asserts that a form field behaves correctly with various inputs.
+
+ :param fieldclass: the class of the field to be tested.
+ :param valid: a dictionary mapping valid inputs to their expected cleaned
+ values.
+ :param invalid: a dictionary mapping invalid inputs to one or more raised
+ error messages.
+ :param field_args: the args passed to instantiate the field.
+ :param field_kwargs: the kwargs passed to instantiate the field.
+ :param empty_value: the expected clean output for inputs in ``EMPTY_VALUES``.
+
+ For example, the following code tests that an ``EmailField`` accepts
+ "a@a.com" as a valid email address, but rejects "aaa" with a reasonable
+ error message::
+
+ self.assertFieldOutput(EmailField, {'a@a.com': 'a@a.com'}, {'aaa': [u'Enter a valid e-mail address.']})
+
+
.. method:: TestCase.assertContains(response, text, count=None, status_code=200, msg_prefix='')
Asserts that a ``Response`` instance produced the given ``status_code`` and
View
12 tests/regressiontests/forms/localflavor/__init__.py
@@ -1,11 +1 @@
-from django.forms import EmailField
-from utils import LocalFlavorTestCase
-
-class AssertFieldOutputTests(LocalFlavorTestCase):
-
- def test_assert_field_output(self):
- error_invalid = [u'Enter a valid e-mail address.']
- self.assertFieldOutput(EmailField, {'a@a.com': 'a@a.com'}, {'aaa': error_invalid})
- self.assertRaises(AssertionError, self.assertFieldOutput, EmailField, {'a@a.com': 'a@a.com'}, {'aaa': error_invalid + [u'Another error']})
- self.assertRaises(AssertionError, self.assertFieldOutput, EmailField, {'a@a.com': 'Wrong output'}, {'aaa': error_invalid})
- self.assertRaises(AssertionError, self.assertFieldOutput, EmailField, {'a@a.com': 'a@a.com'}, {'aaa': [u'Come on, gimme some well formatted data, dude.']})
+#
View
4 tests/regressiontests/forms/localflavor/ar.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.ar.forms import (ARProvinceSelect,
ARPostalCodeField, ARDNIField, ARCUITField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class ARLocalFlavorTests(LocalFlavorTestCase):
+class ARLocalFlavorTests(SimpleTestCase):
def test_ARProvinceSelect(self):
f = ARProvinceSelect()
out = u'''<select name="provincias">
View
4 tests/regressiontests/forms/localflavor/at.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.at.forms import (ATZipCodeField, ATStateSelect,
ATSocialSecurityNumberField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class ATLocalFlavorTests(LocalFlavorTestCase):
+class ATLocalFlavorTests(SimpleTestCase):
def test_ATStateSelect(self):
f = ATStateSelect()
out = u'''<select name="bundesland">
View
4 tests/regressiontests/forms/localflavor/au.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.au.forms import (AUPostCodeField,
AUPhoneNumberField, AUStateSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class AULocalFlavorTests(LocalFlavorTestCase):
+class AULocalFlavorTests(SimpleTestCase):
def test_AUStateSelect(self):
f = AUStateSelect()
out = u'''<select name="state">
View
4 tests/regressiontests/forms/localflavor/be.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.be.forms import (BEPostalCodeField,
BEPhoneNumberField, BERegionSelect, BEProvinceSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class BELocalFlavorTests(LocalFlavorTestCase):
+class BELocalFlavorTests(SimpleTestCase):
def test_BEPostalCodeField(self):
error_format = [u'Enter a valid postal code in the range and format 1XXX - 9XXX.']
valid = {
View
4 tests/regressiontests/forms/localflavor/br.py
@@ -2,10 +2,10 @@
BRCNPJField, BRCPFField, BRPhoneNumberField, BRStateSelect,
BRStateChoiceField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class BRLocalFlavorTests(LocalFlavorTestCase):
+class BRLocalFlavorTests(SimpleTestCase):
def test_BRZipCodeField(self):
error_format = [u'Enter a zip code in the format XXXXX-XXX.']
valid = {
View
4 tests/regressiontests/forms/localflavor/ca.py
@@ -4,10 +4,10 @@
CAPhoneNumberField, CAProvinceField, CAProvinceSelect,
CASocialInsuranceNumberField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class CALocalFlavorTests(LocalFlavorTestCase):
+class CALocalFlavorTests(SimpleTestCase):
def setUp(self):
self.save_warnings_state()
warnings.filterwarnings(
View
4 tests/regressiontests/forms/localflavor/ch.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.ch.forms import (CHZipCodeField,
CHPhoneNumberField, CHIdentityCardNumberField, CHStateSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class CHLocalFlavorTests(LocalFlavorTestCase):
+class CHLocalFlavorTests(SimpleTestCase):
def test_CHStateSelect(self):
f = CHStateSelect()
out = u'''<select name="state">
View
4 tests/regressiontests/forms/localflavor/cl.py
@@ -1,9 +1,9 @@
from django.contrib.localflavor.cl.forms import CLRutField, CLRegionSelect
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class CLLocalFlavorTests(LocalFlavorTestCase):
+class CLLocalFlavorTests(SimpleTestCase):
def test_CLRegionSelect(self):
f = CLRegionSelect()
out = u'''<select name="foo">
View
4 tests/regressiontests/forms/localflavor/cn.py
@@ -2,9 +2,9 @@
from django.contrib.localflavor.cn.forms import (CNProvinceSelect,
CNPostCodeField, CNIDCardField, CNPhoneNumberField, CNCellNumberField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class CNLocalFlavorTests(LocalFlavorTestCase):
+class CNLocalFlavorTests(SimpleTestCase):
def test_CNProvinceSelect(self):
f = CNProvinceSelect()
correct_output = u'''<select name="provinces">
View
4 tests/regressiontests/forms/localflavor/co.py
@@ -1,8 +1,8 @@
from django.contrib.localflavor.co.forms import CODepartmentSelect
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class COLocalFlavorTests(LocalFlavorTestCase):
+class COLocalFlavorTests(SimpleTestCase):
def test_CODepartmentSelect(self):
d = CODepartmentSelect()
out = u"""<select name="department">
View
4 tests/regressiontests/forms/localflavor/cz.py
@@ -4,10 +4,10 @@
CZRegionSelect, CZBirthNumberField, CZICNumberField)
from django.core.exceptions import ValidationError
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class CZLocalFlavorTests(LocalFlavorTestCase):
+class CZLocalFlavorTests(SimpleTestCase):
def setUp(self):
self.save_warnings_state()
warnings.filterwarnings(
View
4 tests/regressiontests/forms/localflavor/de.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.de.forms import (DEZipCodeField, DEStateSelect,
DEIdentityCardNumberField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class DELocalFlavorTests(LocalFlavorTestCase):
+class DELocalFlavorTests(SimpleTestCase):
def test_DEStateSelect(self):
f = DEStateSelect()
out = u'''<select name="states">
View
4 tests/regressiontests/forms/localflavor/ec.py
@@ -1,8 +1,8 @@
from django.contrib.localflavor.ec.forms import ECProvinceSelect
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class ECLocalFlavorTests(LocalFlavorTestCase):
+class ECLocalFlavorTests(SimpleTestCase):
def test_ECProvinceSelect(self):
p = ECProvinceSelect()
out = u"""<select name="province">
View
4 tests/regressiontests/forms/localflavor/es.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.es.forms import (ESPostalCodeField, ESPhoneNumberField,
ESIdentityCardNumberField, ESCCCField, ESRegionSelect, ESProvinceSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class ESLocalFlavorTests(LocalFlavorTestCase):
+class ESLocalFlavorTests(SimpleTestCase):
def test_ESRegionSelect(self):
f = ESRegionSelect()
out = u'''<select name="regions">
View
4 tests/regressiontests/forms/localflavor/fi.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.fi.forms import (FIZipCodeField,
FISocialSecurityNumber, FIMunicipalitySelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class FILocalFlavorTests(LocalFlavorTestCase):
+class FILocalFlavorTests(SimpleTestCase):
def test_FIMunicipalitySelect(self):
f = FIMunicipalitySelect()
out = u'''<select name="municipalities">
View
4 tests/regressiontests/forms/localflavor/fr.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.fr.forms import (FRZipCodeField,
FRPhoneNumberField, FRDepartmentSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class FRLocalFlavorTests(LocalFlavorTestCase):
+class FRLocalFlavorTests(SimpleTestCase):
def test_FRZipCodeField(self):
error_format = [u'Enter a zip code in the format XXXXX.']
valid = {
View
4 tests/regressiontests/forms/localflavor/gb.py
@@ -1,9 +1,9 @@
from django.contrib.localflavor.gb.forms import GBPostcodeField
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class GBLocalFlavorTests(LocalFlavorTestCase):
+class GBLocalFlavorTests(SimpleTestCase):
def test_GBPostcodeField(self):
error_invalid = [u'Enter a valid postcode.']
valid = {
View
4 tests/regressiontests/forms/localflavor/generic.py
@@ -2,10 +2,10 @@
from django.contrib.localflavor.generic.forms import DateField, DateTimeField
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class GenericLocalFlavorTests(LocalFlavorTestCase):
+class GenericLocalFlavorTests(SimpleTestCase):
def test_GenericDateField(self):
error_invalid = [u'Enter a valid date.']
valid = {
View
4 tests/regressiontests/forms/localflavor/hr.py
@@ -4,9 +4,9 @@
HRLicensePlateField, HRPostalCodeField, HROIBField, HRJMBGField,
HRJMBAGField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class HRLocalFlavorTests(LocalFlavorTestCase):
+class HRLocalFlavorTests(SimpleTestCase):
def test_HRCountySelect(self):
f = HRCountySelect()
out = u'''<select name="county">
View
4 tests/regressiontests/forms/localflavor/id.py
@@ -4,10 +4,10 @@
IDPostCodeField, IDNationalIdentityNumberField, IDLicensePlateField,
IDProvinceSelect, IDLicensePlatePrefixSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class IDLocalFlavorTests(LocalFlavorTestCase):
+class IDLocalFlavorTests(SimpleTestCase):
def setUp(self):
self.save_warnings_state()
warnings.filterwarnings(
View
4 tests/regressiontests/forms/localflavor/ie.py
@@ -1,9 +1,9 @@
from django.contrib.localflavor.ie.forms import IECountySelect
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class IELocalFlavorTests(LocalFlavorTestCase):
+class IELocalFlavorTests(SimpleTestCase):
def test_IECountySelect(self):
f = IECountySelect()
out = u'''<select name="counties">
View
4 tests/regressiontests/forms/localflavor/il.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.il.forms import (ILPostalCodeField,
ILIDNumberField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class ILLocalFlavorTests(LocalFlavorTestCase):
+class ILLocalFlavorTests(SimpleTestCase):
def test_ILPostalCodeField(self):
error_format = [u'Enter a postal code in the format XXXXX']
valid = {
View
4 tests/regressiontests/forms/localflavor/in_.py
@@ -1,11 +1,11 @@
from django.contrib.localflavor.in_.forms import (INZipCodeField,
INStateField, INStateSelect, INPhoneNumberField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class INLocalFlavorTests(LocalFlavorTestCase):
+class INLocalFlavorTests(SimpleTestCase):
def test_INPhoneNumberField(self):
error_format = [u'Phone numbers must be in 02X-8X or 03X-7X or 04X-6X format.']
valid = {
View
4 tests/regressiontests/forms/localflavor/is_.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.is_.forms import (ISIdNumberField,
ISPhoneNumberField, ISPostalCodeSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class ISLocalFlavorTests(LocalFlavorTestCase):
+class ISLocalFlavorTests(SimpleTestCase):
def test_ISPostalCodeSelect(self):
f = ISPostalCodeSelect()
out = u'''<select name="foo">
View
4 tests/regressiontests/forms/localflavor/it.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.it.forms import (ITZipCodeField, ITRegionSelect,
ITSocialSecurityNumberField, ITVatNumberField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class ITLocalFlavorTests(LocalFlavorTestCase):
+class ITLocalFlavorTests(SimpleTestCase):
def test_ITRegionSelect(self):
f = ITRegionSelect()
out = u'''<select name="regions">
View
4 tests/regressiontests/forms/localflavor/jp.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.jp.forms import (JPPostalCodeField,
JPPrefectureSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class JPLocalFlavorTests(LocalFlavorTestCase):
+class JPLocalFlavorTests(SimpleTestCase):
def test_JPPrefectureSelect(self):
f = JPPrefectureSelect()
out = u'''<select name="prefecture">
View
4 tests/regressiontests/forms/localflavor/kw.py
@@ -1,9 +1,9 @@
from django.contrib.localflavor.kw.forms import KWCivilIDNumberField
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class KWLocalFlavorTests(LocalFlavorTestCase):
+class KWLocalFlavorTests(SimpleTestCase):
def test_KWCivilIDNumberField(self):
error_invalid = [u'Enter a valid Kuwaiti Civil ID number']
valid = {
View
4 tests/regressiontests/forms/localflavor/mk.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.mk.forms import (
MKIdentityCardNumberField, MKMunicipalitySelect, UMCNField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class MKLocalFlavorTests(LocalFlavorTestCase):
+class MKLocalFlavorTests(SimpleTestCase):
def test_MKIdentityCardNumberField(self):
error_invalid = [u'Identity card numbers must contain either 4 to 7 '
View
4 tests/regressiontests/forms/localflavor/mx.py
@@ -2,10 +2,10 @@
from django.contrib.localflavor.mx.forms import (MXZipCodeField, MXRFCField,
MXStateSelect, MXCURPField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class MXLocalFlavorTests(LocalFlavorTestCase):
+class MXLocalFlavorTests(SimpleTestCase):
def test_MXStateSelect(self):
f = MXStateSelect()
out = u'''<select name="state">
View
4 tests/regressiontests/forms/localflavor/nl.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.nl.forms import (NLPhoneNumberField,
NLZipCodeField, NLSoFiNumberField, NLProvinceSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class NLLocalFlavorTests(LocalFlavorTestCase):
+class NLLocalFlavorTests(SimpleTestCase):
def test_NLProvinceSelect(self):
f = NLProvinceSelect()
out = u'''<select name="provinces">
View
4 tests/regressiontests/forms/localflavor/pl.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.pl.forms import (PLProvinceSelect,
PLCountySelect, PLPostalCodeField, PLNIPField, PLPESELField, PLNationalIDCardNumberField, PLREGONField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class PLLocalFlavorTests(LocalFlavorTestCase):
+class PLLocalFlavorTests(SimpleTestCase):
def test_PLProvinceSelect(self):
f = PLProvinceSelect()
out = u'''<select name="voivodeships">
View
4 tests/regressiontests/forms/localflavor/pt.py
@@ -1,9 +1,9 @@
from django.contrib.localflavor.pt.forms import PTZipCodeField, PTPhoneNumberField
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class PTLocalFlavorTests(LocalFlavorTestCase):
+class PTLocalFlavorTests(SimpleTestCase):
def test_PTZipCodeField(self):
error_format = [u'Enter a zip code in the format XXXX-XXX.']
valid = {
View
4 tests/regressiontests/forms/localflavor/py.py
@@ -1,9 +1,9 @@
from django.contrib.localflavor.py.forms import (PyDepartmentSelect,
PyNumberedDepartmentSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class PYLocalFlavorTests(LocalFlavorTestCase):
+class PYLocalFlavorTests(SimpleTestCase):
def test_PyDepartmentSelect(self):
py = PyDepartmentSelect()
out = u'''<select name="department">
View
4 tests/regressiontests/forms/localflavor/ro.py
@@ -3,10 +3,10 @@
ROCountyField, ROCountySelect, ROIBANField, ROPhoneNumberField,
ROPostalCodeField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class ROLocalFlavorTests(LocalFlavorTestCase):
+class ROLocalFlavorTests(SimpleTestCase):
def test_ROCountySelect(self):
f = ROCountySelect()
out = u'''<select name="county">
View
4 tests/regressiontests/forms/localflavor/ru.py
@@ -1,9 +1,9 @@
from django.contrib.localflavor.ru.forms import *
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class RULocalFlavorTests(LocalFlavorTestCase):
+class RULocalFlavorTests(SimpleTestCase):
def test_RUPassportNumberField(self):
error = [u'Enter a passport number in the format XXXX XXXXXX.']
View
4 tests/regressiontests/forms/localflavor/se.py
@@ -4,10 +4,10 @@
SEPostalCodeField)
import datetime
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class SELocalFlavorTests(LocalFlavorTestCase):
+class SELocalFlavorTests(SimpleTestCase):
def setUp(self):
# Mocking datetime.date to make sure
View
4 tests/regressiontests/forms/localflavor/sk.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.sk.forms import (SKRegionSelect,
SKPostalCodeField, SKDistrictSelect)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class SKLocalFlavorTests(LocalFlavorTestCase):
+class SKLocalFlavorTests(SimpleTestCase):
def test_SKRegionSelect(self):
f = SKRegionSelect()
out = u'''<select name="regions">
View
4 tests/regressiontests/forms/localflavor/us.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.us.forms import (USZipCodeField,
USPhoneNumberField, USStateField, USStateSelect, USSocialSecurityNumberField)
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class USLocalFlavorTests(LocalFlavorTestCase):
+class USLocalFlavorTests(SimpleTestCase):
def test_USStateSelect(self):
f = USStateSelect()
out = u'''<select name="state">
View
64 tests/regressiontests/forms/localflavor/utils.py
@@ -1,64 +0,0 @@
-from __future__ import with_statement
-
-from django.core.exceptions import ValidationError
-from django.core.validators import EMPTY_VALUES
-from django.forms.fields import CharField
-from django.test.utils import get_warnings_state, restore_warnings_state
-from django.utils.unittest import TestCase
-
-
-class LocalFlavorTestCase(TestCase):
- # NOTE: These are copied from the TestCase Django uses for tests which
- # access the database
- def save_warnings_state(self):
- self._warnings_state = get_warnings_state()
-
- def restore_warnings_state(self):
- restore_warnings_state(self._warnings_state)
-
- def assertFieldOutput(self, fieldclass, valid, invalid, field_args=None,
- field_kwargs=None, empty_value=u''):
- """
- Asserts that a field behaves correctly with various inputs.
-
- Args:
- fieldclass: the class of the field to be tested.
- valid: a dictionary mapping valid inputs to their expected
- cleaned values.
- invalid: a dictionary mapping invalid inputs to one or more
- raised error messages.
- field_args: the args passed to instantiate the field
- field_kwargs: the kwargs passed to instantiate the field
- empty_value: the expected clean output for inputs in EMPTY_VALUES
-
- """
- if field_args is None:
- field_args = []
- if field_kwargs is None:
- field_kwargs = {}
- required = fieldclass(*field_args, **field_kwargs)
- optional = fieldclass(*field_args, **dict(field_kwargs, required=False))
- # test valid inputs
- for input, output in valid.items():
- self.assertEqual(required.clean(input), output)
- self.assertEqual(optional.clean(input), output)
- # test invalid inputs
- for input, errors in invalid.items():
- with self.assertRaises(ValidationError) as context_manager:
- required.clean(input)
- self.assertEqual(context_manager.exception.messages, errors)
-
- with self.assertRaises(ValidationError) as context_manager:
- optional.clean(input)
- self.assertEqual(context_manager.exception.messages, errors)
- # test required inputs
- error_required = [u'This field is required.']
- for e in EMPTY_VALUES:
- with self.assertRaises(ValidationError) as context_manager:
- required.clean(e)
- self.assertEqual(context_manager.exception.messages, error_required)
- self.assertEqual(optional.clean(e), empty_value)
- # test that max_length and min_length are always accepted
- if issubclass(fieldclass, CharField):
- field_kwargs.update({'min_length':2, 'max_length':20})
- self.assertTrue(isinstance(fieldclass(*field_args, **field_kwargs), fieldclass))
View
4 tests/regressiontests/forms/localflavor/uy.py
@@ -1,10 +1,10 @@
from django.contrib.localflavor.uy.forms import UYDepartamentSelect, UYCIField
from django.contrib.localflavor.uy.util import get_validation_digit
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class UYLocalFlavorTests(LocalFlavorTestCase):
+class UYLocalFlavorTests(SimpleTestCase):
def test_UYDepartmentSelect(self):
f = UYDepartamentSelect()
out = u'''<select name="departamentos">
View
4 tests/regressiontests/forms/localflavor/za.py
@@ -1,9 +1,9 @@
from django.contrib.localflavor.za.forms import ZAIDField, ZAPostCodeField
-from utils import LocalFlavorTestCase
+from django.test import SimpleTestCase
-class ZALocalFlavorTests(LocalFlavorTestCase):
+class ZALocalFlavorTests(SimpleTestCase):
def test_ZAIDField(self):
error_invalid = [u'Enter a valid South African ID number']
valid = {
View
1  tests/regressiontests/forms/localflavortests.py
@@ -1,4 +1,3 @@
-from localflavor import AssertFieldOutputTests
from localflavor.ar import ARLocalFlavorTests
from localflavor.at import ATLocalFlavorTests
from localflavor.au import AULocalFlavorTests
View
1  tests/regressiontests/forms/tests/__init__.py
@@ -53,5 +53,4 @@
USLocalFlavorTests,
UYLocalFlavorTests,
ZALocalFlavorTests,
- AssertFieldOutputTests,
)
View
11 tests/regressiontests/test_utils/tests.py
@@ -1,5 +1,6 @@
from __future__ import with_statement
+from django.forms import EmailField
from django.test import SimpleTestCase, TestCase, skipUnlessDBFeature
from django.utils.unittest import skip
@@ -139,6 +140,16 @@ def func1():
self.assertRaisesMessage(ValueError, "[.*x+]y?", func1)
+class AssertFieldOutputTests(SimpleTestCase):
+
+ def test_assert_field_output(self):
+ error_invalid = [u'Enter a valid e-mail address.']
+ self.assertFieldOutput(EmailField, {'a@a.com': 'a@a.com'}, {'aaa': error_invalid})
+ self.assertRaises(AssertionError, self.assertFieldOutput, EmailField, {'a@a.com': 'a@a.com'}, {'aaa': error_invalid + [u'Another error']})
+ self.assertRaises(AssertionError, self.assertFieldOutput, EmailField, {'a@a.com': 'Wrong output'}, {'aaa': error_invalid})
+ self.assertRaises(AssertionError, self.assertFieldOutput, EmailField, {'a@a.com': 'a@a.com'}, {'aaa': [u'Come on, gimme some well formatted data, dude.']})
+
+
__test__ = {"API_TEST": r"""
# Some checks of the doctest output normalizer.
# Standard doctests do fairly
Please sign in to comment.
Something went wrong with that request. Please try again.