summaryrefslogtreecommitdiff
path: root/tests/regressiontests/generic_relations_regress
diff options
context:
space:
mode:
authorJustin Bronn <jbronn@gmail.com>2010-01-22 18:39:48 +0000
committerJustin Bronn <jbronn@gmail.com>2010-01-22 18:39:48 +0000
commitc1584383fa7b83b9c00a40a1f0b367b91f2f7382 (patch)
tree4cfe896be9fa166357d291e6f0d5902f480b68ef /tests/regressiontests/generic_relations_regress
parent5ec44450df55d53416f9e1a17e73a695c36d749b (diff)
Fixed #12664 -- Fixed `GenericRelation.m2m_reverse_name` to return the correct pk column name.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12276 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'tests/regressiontests/generic_relations_regress')
-rw-r--r--tests/regressiontests/generic_relations_regress/models.py28
-rw-r--r--tests/regressiontests/generic_relations_regress/tests.py23
2 files changed, 42 insertions, 9 deletions
diff --git a/tests/regressiontests/generic_relations_regress/models.py b/tests/regressiontests/generic_relations_regress/models.py
index 1a4826aaed..8192dc60d3 100644
--- a/tests/regressiontests/generic_relations_regress/models.py
+++ b/tests/regressiontests/generic_relations_regress/models.py
@@ -13,10 +13,30 @@ class Link(models.Model):
class Place(models.Model):
name = models.CharField(max_length=100)
links = generic.GenericRelation(Link)
-
+
def __unicode__(self):
return "Place: %s" % self.name
-
-class Restaurant(Place):
+
+class Restaurant(Place):
+ def __unicode__(self):
+ return "Restaurant: %s" % self.name
+
+class Address(models.Model):
+ street = models.CharField(max_length=80)
+ city = models.CharField(max_length=50)
+ state = models.CharField(max_length=2)
+ zipcode = models.CharField(max_length=5)
+ content_type = models.ForeignKey(ContentType)
+ object_id = models.PositiveIntegerField()
+ content_object = generic.GenericForeignKey()
+
+ def __unicode__(self):
+ return '%s %s, %s %s' % (self.street, self.city, self.state, self.zipcode)
+
+class Person(models.Model):
+ account = models.IntegerField(primary_key=True)
+ name = models.CharField(max_length=128)
+ addresses = generic.GenericRelation(Address)
+
def __unicode__(self):
- return "Restaurant: %s" % self.name \ No newline at end of file
+ return self.name
diff --git a/tests/regressiontests/generic_relations_regress/tests.py b/tests/regressiontests/generic_relations_regress/tests.py
index 6f0863d7b4..e1cc85dcdc 100644
--- a/tests/regressiontests/generic_relations_regress/tests.py
+++ b/tests/regressiontests/generic_relations_regress/tests.py
@@ -1,19 +1,32 @@
from django.test import TestCase
from django.contrib.contenttypes.models import ContentType
-from models import Link, Place, Restaurant
+from models import Link, Place, Restaurant, Person, Address
class GenericRelationTests(TestCase):
-
+
def test_inherited_models_content_type(self):
"""
Test that GenericRelations on inherited classes use the correct content
type.
"""
-
+
p = Place.objects.create(name="South Park")
- r = Restaurant.objects.create(name="Chubby's")
+ r = Restaurant.objects.create(name="Chubby's")
l1 = Link.objects.create(content_object=p)
l2 = Link.objects.create(content_object=r)
self.assertEqual(list(p.links.all()), [l1])
self.assertEqual(list(r.links.all()), [l2])
- \ No newline at end of file
+
+ def test_reverse_relation_pk(self):
+ """
+ Test that the correct column name is used for the primary key on the
+ originating model of a query. See #12664.
+ """
+ p = Person.objects.create(account=23, name='Chef')
+ a = Address.objects.create(street='123 Anywhere Place',
+ city='Conifer', state='CO',
+ zipcode='80433', content_object=p)
+
+ qs = Person.objects.filter(addresses__zipcode='80433')
+ self.assertEqual(1, qs.count())
+ self.assertEqual('Chef', qs[0].name)