mirror of
https://github.com/django/django.git
synced 2025-10-23 21:59:11 +00:00
Fixed #19362 -- Detected invalid use of @python_2_unicode_compatible.
Thanks m3wolf for the report and akaariai for reproducing the problem.
This commit is contained in:
@@ -416,6 +416,11 @@ class Model(six.with_metaclass(ModelBase, object)):
|
||||
|
||||
def __str__(self):
|
||||
if not six.PY3 and hasattr(self, '__unicode__'):
|
||||
if type(self).__unicode__ == Model.__str__:
|
||||
klass_name = type(self).__name__
|
||||
raise RuntimeError("%s.__unicode__ is aliased to __str__. Did"
|
||||
" you apply @python_2_unicode_compatible"
|
||||
" without defining __str__?" % klass_name)
|
||||
return force_text(self).encode('utf-8')
|
||||
return '%s object' % self.__class__.__name__
|
||||
|
||||
|
@@ -27,6 +27,14 @@ class Article(models.Model):
|
||||
# in ASCII.
|
||||
return self.headline
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class BrokenArticle(models.Model):
|
||||
headline = models.CharField(max_length=100)
|
||||
pub_date = models.DateTimeField()
|
||||
|
||||
def __unicode__(self): # instead of __str__
|
||||
return self.headline
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class InternationalArticle(models.Model):
|
||||
headline = models.CharField(max_length=100)
|
||||
|
@@ -7,7 +7,7 @@ from django.test import TestCase
|
||||
from django.utils import six
|
||||
from django.utils.unittest import skipIf
|
||||
|
||||
from .models import Article, InternationalArticle
|
||||
from .models import Article, BrokenArticle, InternationalArticle
|
||||
|
||||
|
||||
class SimpleTests(TestCase):
|
||||
@@ -21,6 +21,16 @@ class SimpleTests(TestCase):
|
||||
self.assertEqual(str(a), str('Area man programs in Python'))
|
||||
self.assertEqual(repr(a), str('<Article: Area man programs in Python>'))
|
||||
|
||||
@skipIf(six.PY3, "tests Model's default __str__ method under Python 2")
|
||||
def test_broken(self):
|
||||
# Regression test for #19362.
|
||||
a = BrokenArticle.objects.create(
|
||||
headline='Girl wins €12.500 in lottery',
|
||||
pub_date=datetime.datetime(2005, 7, 28)
|
||||
)
|
||||
self.assertRaisesRegexp(RuntimeError, "Did you apply "
|
||||
"@python_2_unicode_compatible without defining __str__\?", str, a)
|
||||
|
||||
def test_international(self):
|
||||
a = InternationalArticle.objects.create(
|
||||
headline='Girl wins €12.500 in lottery',
|
||||
|
Reference in New Issue
Block a user