Fixed #14695 -- Stopped model fields from incorrectly overwriting the field name during model initialization if it was already passed as a keyword argument. Thanks, erikrose and willhardy.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@16614 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
c0a4c04e2a
commit
1abafe696e
|
@ -220,15 +220,16 @@ class Field(object):
|
||||||
except KeyError:
|
except KeyError:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
@property
|
||||||
def unique(self):
|
def unique(self):
|
||||||
return self._unique or self.primary_key
|
return self._unique or self.primary_key
|
||||||
unique = property(unique)
|
|
||||||
|
|
||||||
def set_attributes_from_name(self, name):
|
def set_attributes_from_name(self, name):
|
||||||
self.name = name
|
if not self.name:
|
||||||
|
self.name = name
|
||||||
self.attname, self.column = self.get_attname_column()
|
self.attname, self.column = self.get_attname_column()
|
||||||
if self.verbose_name is None and name:
|
if self.verbose_name is None and self.name:
|
||||||
self.verbose_name = name.replace('_', ' ')
|
self.verbose_name = self.name.replace('_', ' ')
|
||||||
|
|
||||||
def contribute_to_class(self, cls, name):
|
def contribute_to_class(self, cls, name):
|
||||||
self.set_attributes_from_name(name)
|
self.set_attributes_from_name(name)
|
||||||
|
|
|
@ -66,6 +66,9 @@ class BooleanModel(models.Model):
|
||||||
bfield = models.BooleanField()
|
bfield = models.BooleanField()
|
||||||
string = models.CharField(max_length=10, default='abc')
|
string = models.CharField(max_length=10, default='abc')
|
||||||
|
|
||||||
|
class RenamedField(models.Model):
|
||||||
|
modelname = models.IntegerField(name="fieldname", choices=((1,'One'),))
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
# FileField
|
# FileField
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@ from django.db import models
|
||||||
from django.db.models.fields.files import FieldFile
|
from django.db.models.fields.files import FieldFile
|
||||||
from django.utils import unittest
|
from django.utils import unittest
|
||||||
|
|
||||||
from models import Foo, Bar, Whiz, BigD, BigS, Image, BigInt, Post, NullBooleanModel, BooleanModel, Document
|
from models import Foo, Bar, Whiz, BigD, BigS, Image, BigInt, Post, NullBooleanModel, BooleanModel, Document, RenamedField
|
||||||
|
|
||||||
# If PIL available, do these tests.
|
# If PIL available, do these tests.
|
||||||
if Image:
|
if Image:
|
||||||
|
@ -53,6 +53,15 @@ class BasicFieldTests(test.TestCase):
|
||||||
f = models.fields.CharField()
|
f = models.fields.CharField()
|
||||||
self.assertEqual(repr(f), '<django.db.models.fields.CharField>')
|
self.assertEqual(repr(f), '<django.db.models.fields.CharField>')
|
||||||
|
|
||||||
|
def test_field_name(self):
|
||||||
|
"""
|
||||||
|
Regression test for #14695: explicitly defined field name overwritten
|
||||||
|
by model's attribute name.
|
||||||
|
"""
|
||||||
|
instance = RenamedField()
|
||||||
|
self.assertTrue(hasattr(instance, 'get_fieldname_display'))
|
||||||
|
self.assertFalse(hasattr(instance, 'get_modelname_display'))
|
||||||
|
|
||||||
class DecimalFieldTests(test.TestCase):
|
class DecimalFieldTests(test.TestCase):
|
||||||
def test_to_python(self):
|
def test_to_python(self):
|
||||||
f = models.DecimalField(max_digits=4, decimal_places=2)
|
f = models.DecimalField(max_digits=4, decimal_places=2)
|
||||||
|
|
Loading…
Reference in New Issue