summaryrefslogtreecommitdiff
path: root/parts/django/tests/modeltests/reverse_lookup
diff options
context:
space:
mode:
Diffstat (limited to 'parts/django/tests/modeltests/reverse_lookup')
-rw-r--r--parts/django/tests/modeltests/reverse_lookup/__init__.py0
-rw-r--r--parts/django/tests/modeltests/reverse_lookup/models.py28
-rw-r--r--parts/django/tests/modeltests/reverse_lookup/tests.py49
3 files changed, 77 insertions, 0 deletions
diff --git a/parts/django/tests/modeltests/reverse_lookup/__init__.py b/parts/django/tests/modeltests/reverse_lookup/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/parts/django/tests/modeltests/reverse_lookup/__init__.py
diff --git a/parts/django/tests/modeltests/reverse_lookup/models.py b/parts/django/tests/modeltests/reverse_lookup/models.py
new file mode 100644
index 0000000..2ffdc39
--- /dev/null
+++ b/parts/django/tests/modeltests/reverse_lookup/models.py
@@ -0,0 +1,28 @@
+"""
+25. Reverse lookups
+
+This demonstrates the reverse lookup features of the database API.
+"""
+
+from django.db import models
+
+class User(models.Model):
+ name = models.CharField(max_length=200)
+
+ def __unicode__(self):
+ return self.name
+
+class Poll(models.Model):
+ question = models.CharField(max_length=200)
+ creator = models.ForeignKey(User)
+
+ def __unicode__(self):
+ return self.question
+
+class Choice(models.Model):
+ name = models.CharField(max_length=100)
+ poll = models.ForeignKey(Poll, related_name="poll_choice")
+ related_poll = models.ForeignKey(Poll, related_name="related_choice")
+
+ def __unicode__(self):
+ return self.name
diff --git a/parts/django/tests/modeltests/reverse_lookup/tests.py b/parts/django/tests/modeltests/reverse_lookup/tests.py
new file mode 100644
index 0000000..9a6e306
--- /dev/null
+++ b/parts/django/tests/modeltests/reverse_lookup/tests.py
@@ -0,0 +1,49 @@
+from django.test import TestCase
+from django.core.exceptions import FieldError
+
+from models import User, Poll, Choice
+
+class ReverseLookupTests(TestCase):
+
+ def setUp(self):
+ john = User.objects.create(name="John Doe")
+ jim = User.objects.create(name="Jim Bo")
+ first_poll = Poll.objects.create(
+ question="What's the first question?",
+ creator=john
+ )
+ second_poll = Poll.objects.create(
+ question="What's the second question?",
+ creator=jim
+ )
+ new_choice = Choice.objects.create(
+ poll=first_poll,
+ related_poll=second_poll,
+ name="This is the answer."
+ )
+
+ def test_reverse_by_field(self):
+ u1 = User.objects.get(
+ poll__question__exact="What's the first question?"
+ )
+ self.assertEqual(u1.name, "John Doe")
+
+ u2 = User.objects.get(
+ poll__question__exact="What's the second question?"
+ )
+ self.assertEqual(u2.name, "Jim Bo")
+
+ def test_reverse_by_related_name(self):
+ p1 = Poll.objects.get(poll_choice__name__exact="This is the answer.")
+ self.assertEqual(p1.question, "What's the first question?")
+
+ p2 = Poll.objects.get(
+ related_choice__name__exact="This is the answer.")
+ self.assertEqual(p2.question, "What's the second question?")
+
+ def test_reverse_field_name_disallowed(self):
+ """
+ If a related_name is given you can't use the field name instead
+ """
+ self.assertRaises(FieldError, Poll.objects.get,
+ choice__name__exact="This is the answer")