diff --git a/django/forms/fields.py b/django/forms/fields.py index cf1daa0003..9446ed2eea 100644 --- a/django/forms/fields.py +++ b/django/forms/fields.py @@ -180,7 +180,6 @@ class CharField(Field): return {'maxlength': str(self.max_length)} class IntegerField(Field): - default_validators = [validators.validate_integer] default_error_messages = { 'invalid': _(u'Enter a whole number.'), 'max_value': _(u'Ensure this value is less than or equal to %s.'), diff --git a/django/forms/forms.py b/django/forms/forms.py index 6b6f1c5971..b5c0fc06e0 100644 --- a/django/forms/forms.py +++ b/django/forms/forms.py @@ -247,6 +247,20 @@ class BaseForm(StrAndUnicode): self._errors[name] = self.error_class(e.messages) if name in self.cleaned_data: del self.cleaned_data[name] + + # run all the validators after the fields have been cleaned since they + # need access to all_values + for name, field in self.fields.items(): + if not name in self.cleaned_data: + continue + for v in field.validators: + try: + v(self.cleaned_data[name], all_values=self.cleaned_data) + except ValidationError, e: + self._errors.setdefault(name, self.error_class()).extend(e.messages) + if name in self.cleaned_data: + del self.cleaned_data[name] + try: self.cleaned_data = self.clean() except ValidationError, e: