[1.9.x] Fixed #25560 -- Made empty string related_name invalid.

Thanks to Ali Lotfi for the initial report and patch
and Tim Graham for the review.

Backport of c1b6a8a98b from master
This commit is contained in:
Simon Charette 2015-10-16 12:21:30 -04:00 committed by Tim Graham
parent d8b2645032
commit 3aeb84df25
3 changed files with 3 additions and 2 deletions

View File

@ -124,7 +124,7 @@ class RelatedField(Field):
import re
import keyword
related_name = self.remote_field.related_name
if not related_name:
if related_name is None:
return []
is_valid_id = True
if keyword.iskeyword(related_name):

View File

@ -154,7 +154,7 @@ class ForeignObjectRel(object):
def is_hidden(self):
"Should the related object be hidden?"
return self.related_name is not None and self.related_name[-1] == '+'
return bool(self.related_name) and self.related_name[-1] == '+'
def get_joining_columns(self):
return self.field.get_reverse_joining_columns()

View File

@ -662,6 +662,7 @@ class RelativeFieldTests(IsolatedModelsTestCase):
'ends_with_whitespace_%s' % whitespace,
'with', # a Python keyword
'related_name\n',
'',
]
# Python 2 crashes on non-ASCII strings.
if six.PY3: