Fixed #10413: RelatedManager.add no longer fails silenty when trying to add an object of the wrong type. Thanks, dgouldin.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@10226 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Jacob Kaplan-Moss 2009-03-30 22:41:49 +00:00
parent c8ad87c2dc
commit 6ce25d3be9
4 changed files with 20 additions and 0 deletions

View File

@ -253,6 +253,8 @@ def create_generic_related_manager(superclass):
def add(self, *objs):
for obj in objs:
if not isinstance(obj, self.model):
raise TypeError, "'%s' instance expected" % self.model._meta.object_name
setattr(obj, self.content_type_field_name, self.content_type)
setattr(obj, self.object_id_field_name, self.pk_val)
obj.save()

View File

@ -332,6 +332,8 @@ class ForeignRelatedObjectsDescriptor(object):
def add(self, *objs):
for obj in objs:
if not isinstance(obj, self.model):
raise TypeError, "'%s' instance expected" % self.model._meta.object_name
setattr(obj, rel_field.name, instance)
obj.save()
add.alters_data = True
@ -452,11 +454,14 @@ def create_many_related_manager(superclass, through=False):
# If there aren't any objects, there is nothing to do.
if objs:
from django.db.models.base import Model
# Check that all the objects are of the right type
new_ids = set()
for obj in objs:
if isinstance(obj, self.model):
new_ids.add(obj._get_pk_val())
elif isinstance(obj, Model):
raise TypeError, "'%s' instance expected" % self.model._meta.object_name
else:
new_ids.add(obj)
# Add the newly created or already existing objects to the join table.

View File

@ -61,6 +61,12 @@ ValueError: 'Article' instance needs to have a primary key value before a many-t
# Adding a second time is OK
>>> a2.publications.add(p3)
# Adding an object of the wrong type raises TypeError
>>> a2.publications.add(a1)
Traceback (most recent call last):
...
TypeError: 'Publication' instance expected
# Add a Publication directly via publications.add by using keyword arguments.
>>> new_publication = a2.publications.create(title='Highlights for Children')

View File

@ -72,6 +72,13 @@ __test__ = {'API_TESTS':"""
>>> r2.article_set.add(new_article2)
>>> new_article2.reporter.id
2
# Adding an object of the wrong type raises TypeError
>>> r.article_set.add(r2)
Traceback (most recent call last):
...
TypeError: 'Article' instance expected
>>> r.article_set.all()
[<Article: John's second story>, <Article: This is a test>]
>>> r2.article_set.all()