mirror of https://github.com/django/django.git
Fixed #14102 -- Ensure that fields that have been excluded from a form aren't included in the unique_for_* checks, either. Thanks to Travis Cline for the report and fix.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@13598 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
810ed2b22b
commit
015d85aee6
1
AUTHORS
1
AUTHORS
|
@ -108,6 +108,7 @@ answer newbie questions, and generally made Django that much better:
|
||||||
Michal Chruszcz <troll@pld-linux.org>
|
Michal Chruszcz <troll@pld-linux.org>
|
||||||
Can Burak Çilingir <canburak@cs.bilgi.edu.tr>
|
Can Burak Çilingir <canburak@cs.bilgi.edu.tr>
|
||||||
Ian Clelland <clelland@gmail.com>
|
Ian Clelland <clelland@gmail.com>
|
||||||
|
Travis Cline <travis.cline@gmail.com>
|
||||||
Russell Cloran <russell@rucus.net>
|
Russell Cloran <russell@rucus.net>
|
||||||
colin@owlfish.com
|
colin@owlfish.com
|
||||||
crankycoder@gmail.com
|
crankycoder@gmail.com
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
import types
|
import types
|
||||||
import sys
|
import sys
|
||||||
import os
|
|
||||||
from itertools import izip
|
from itertools import izip
|
||||||
import django.db.models.manager # Imported to register signal handler.
|
import django.db.models.manager # Imported to register signal handler.
|
||||||
from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned, FieldError, ValidationError, NON_FIELD_ERRORS
|
from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned, FieldError, ValidationError, NON_FIELD_ERRORS
|
||||||
|
@ -16,7 +15,7 @@ from django.db.models.loading import register_models, get_model
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
import django.utils.copycompat as copy
|
import django.utils.copycompat as copy
|
||||||
from django.utils.functional import curry, update_wrapper
|
from django.utils.functional import curry, update_wrapper
|
||||||
from django.utils.encoding import smart_str, force_unicode, smart_unicode
|
from django.utils.encoding import smart_str, force_unicode
|
||||||
from django.utils.text import get_text_list, capfirst
|
from django.utils.text import get_text_list, capfirst
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
|
||||||
|
@ -744,11 +743,11 @@ class Model(object):
|
||||||
continue
|
continue
|
||||||
if f.unique:
|
if f.unique:
|
||||||
unique_checks.append((model_class, (name,)))
|
unique_checks.append((model_class, (name,)))
|
||||||
if f.unique_for_date:
|
if f.unique_for_date and f.unique_for_date not in exclude:
|
||||||
date_checks.append((model_class, 'date', name, f.unique_for_date))
|
date_checks.append((model_class, 'date', name, f.unique_for_date))
|
||||||
if f.unique_for_year:
|
if f.unique_for_year and f.unique_for_year not in exclude:
|
||||||
date_checks.append((model_class, 'year', name, f.unique_for_year))
|
date_checks.append((model_class, 'year', name, f.unique_for_year))
|
||||||
if f.unique_for_month:
|
if f.unique_for_month and f.unique_for_month not in exclude:
|
||||||
date_checks.append((model_class, 'month', name, f.unique_for_month))
|
date_checks.append((model_class, 'month', name, f.unique_for_month))
|
||||||
return unique_checks, date_checks
|
return unique_checks, date_checks
|
||||||
|
|
||||||
|
|
|
@ -156,6 +156,10 @@ class UniqueTest(TestCase):
|
||||||
form = PostForm({'subtitle': "Finally", "title": "Django 1.0 is released",
|
form = PostForm({'subtitle': "Finally", "title": "Django 1.0 is released",
|
||||||
"slug": "Django 1.0", 'posted': '2008-09-03'}, instance=p)
|
"slug": "Django 1.0", 'posted': '2008-09-03'}, instance=p)
|
||||||
self.assertTrue(form.is_valid())
|
self.assertTrue(form.is_valid())
|
||||||
|
form = PostForm({'title': "Django 1.0 is released"})
|
||||||
|
self.assertFalse(form.is_valid())
|
||||||
|
self.assertEqual(len(form.errors), 1)
|
||||||
|
self.assertEqual(form.errors['posted'], [u'This field is required.'])
|
||||||
|
|
||||||
def test_inherited_unique_for_date(self):
|
def test_inherited_unique_for_date(self):
|
||||||
p = Post.objects.create(title="Django 1.0 is released",
|
p = Post.objects.create(title="Django 1.0 is released",
|
||||||
|
|
|
@ -40,6 +40,15 @@ class GetUniqueCheckTests(unittest.TestCase):
|
||||||
), m._get_unique_checks()
|
), m._get_unique_checks()
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def test_unique_for_date_exclusion(self):
|
||||||
|
m = UniqueForDateModel()
|
||||||
|
self.assertEqual((
|
||||||
|
[(UniqueForDateModel, ('id',))],
|
||||||
|
[(UniqueForDateModel, 'year', 'count', 'end_date'),
|
||||||
|
(UniqueForDateModel, 'month', 'order', 'end_date')]
|
||||||
|
), m._get_unique_checks(exclude='start_date')
|
||||||
|
)
|
||||||
|
|
||||||
class PerformUniqueChecksTest(unittest.TestCase):
|
class PerformUniqueChecksTest(unittest.TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
# Set debug to True to gain access to connection.queries.
|
# Set debug to True to gain access to connection.queries.
|
||||||
|
|
Loading…
Reference in New Issue