Fixed #10015 -- PostgreSQL 8.3+ no longer barfs when passing an integer as a filter() value for a CharField or TextField. Thanks, carljm

git-svn-id: http://code.djangoproject.com/svn/django/trunk@12150 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Adrian Holovaty 2010-01-09 22:05:10 +00:00
parent 1d61a1eb2a
commit 18723e6e24
3 changed files with 26 additions and 1 deletions

View File

@ -565,6 +565,9 @@ class CharField(Field):
return value return value
return smart_unicode(value) return smart_unicode(value)
def get_prep_value(self, value):
return self.to_python(value)
def formfield(self, **kwargs): def formfield(self, **kwargs):
# Passing max_length to forms.CharField means that the value's length # Passing max_length to forms.CharField means that the value's length
# will be validated twice. This is considered acceptable since we want # will be validated twice. This is considered acceptable since we want
@ -1006,6 +1009,11 @@ class TextField(Field):
def get_internal_type(self): def get_internal_type(self):
return "TextField" return "TextField"
def get_prep_value(self, value):
if isinstance(value, basestring) or value is None:
return value
return smart_unicode(value)
def formfield(self, **kwargs): def formfield(self, **kwargs):
defaults = {'widget': forms.Textarea} defaults = {'widget': forms.Textarea}
defaults.update(kwargs) defaults.update(kwargs)

View File

@ -55,6 +55,10 @@ class BigInt(models.Model):
value = models.BigIntegerField() value = models.BigIntegerField()
null_value = models.BigIntegerField(null = True, blank = True) null_value = models.BigIntegerField(null = True, blank = True)
class Post(models.Model):
title = models.CharField(max_length=100)
body = models.TextField()
############################################################################### ###############################################################################
# ImageField # ImageField

View File

@ -6,7 +6,7 @@ from django import forms
from django.db import models from django.db import models
from django.core.exceptions import ValidationError from django.core.exceptions import ValidationError
from models import Foo, Bar, Whiz, BigD, BigS, Image, BigInt from models import Foo, Bar, Whiz, BigD, BigS, Image, BigInt, Post
try: try:
from decimal import Decimal from decimal import Decimal
@ -227,3 +227,16 @@ class BigIntegerFieldTests(django.test.TestCase):
b = BigInt.objects.get(value = '10') b = BigInt.objects.get(value = '10')
self.assertEqual(b.value, 10) self.assertEqual(b.value, 10)
class TypeCoercionTests(django.test.TestCase):
"""
Test that database lookups can accept the wrong types and convert
them with no error: especially on Postgres 8.3+ which does not do
automatic casting at the DB level. See #10015.
"""
def test_lookup_integer_in_charfield(self):
self.assertEquals(Post.objects.filter(title=9).count(), 0)
def test_lookup_integer_in_textfield(self):
self.assertEquals(Post.objects.filter(body=24).count(), 0)