From 223b2721aa501a0603502d9dae499b7f21ae788f Mon Sep 17 00:00:00 2001 From: Joseph Kocherhans Date: Tue, 12 Jan 2010 14:58:24 +0000 Subject: [PATCH] Fixed #12510. Changed ModelChoiceField to stop using some of its superclasses implementation. This could cause more than one query when generating choices. Thanks, Petr Marhoun and Honza Kral. git-svn-id: http://code.djangoproject.com/svn/django/trunk@12211 bcc190cf-cafb-0310-a4f2-bffc1f526a37 --- django/forms/models.py | 6 ++++-- tests/regressiontests/forms/models.py | 28 ++++++++++++++++++++++++++- 2 files changed, 31 insertions(+), 3 deletions(-) diff --git a/django/forms/models.py b/django/forms/models.py index 817de5e9b25..cce23194719 100644 --- a/django/forms/models.py +++ b/django/forms/models.py @@ -903,8 +903,7 @@ class ModelChoiceField(ChoiceField): choices = property(_get_choices, ChoiceField._set_choices) - def clean(self, value): - Field.clean(self, value) + def to_python(self, value): if value in EMPTY_VALUES: return None try: @@ -914,6 +913,9 @@ class ModelChoiceField(ChoiceField): raise ValidationError(self.error_messages['invalid_choice']) return value + def validate(self, value): + return Field.validate(self, value) + class ModelMultipleChoiceField(ModelChoiceField): """A MultipleChoiceField whose choices are a model QuerySet.""" widget = SelectMultiple diff --git a/tests/regressiontests/forms/models.py b/tests/regressiontests/forms/models.py index 3b47b50b004..de91ec67e70 100644 --- a/tests/regressiontests/forms/models.py +++ b/tests/regressiontests/forms/models.py @@ -3,11 +3,13 @@ import datetime import tempfile import shutil -from django.db import models +from django.db import models, connection +from django.conf import settings # Can't import as "forms" due to implementation details in the test suite (the # current file is called "forms" and is already imported). from django import forms as django_forms from django.core.files.storage import FileSystemStorage +from django.test import TestCase temp_storage_location = tempfile.mkdtemp() temp_storage = FileSystemStorage(location=temp_storage_location) @@ -41,6 +43,30 @@ class FileModel(models.Model): class FileForm(django_forms.Form): file1 = django_forms.FileField() +class Group(models.Model): + name = models.CharField(max_length=10) + + def __unicode__(self): + return u'%s' % self.name + +class TestTicket12510(TestCase): + ''' It is not necessary to generate choices for ModelChoiceField (regression test for #12510). ''' + def setUp(self): + self.groups = [Group.objects.create(name=name) for name in 'abc'] + self.old_debug = settings.DEBUG + # turn debug on to get access to connection.queries + settings.DEBUG = True + + def tearDown(self): + settings.DEBUG = self.old_debug + + def test_choices_not_fetched_when_not_rendering(self): + field = django_forms.ModelChoiceField(Group.objects.order_by('-name')) + self.assertEqual('a', field.clean(self.groups[0].pk).name) + # only one query is required to pull the model from DB + self.assertEqual(1, len(connection.queries)) + + __test__ = {'API_TESTS': """ >>> from django.forms.models import ModelForm >>> from django.core.files.uploadedfile import SimpleUploadedFile