2013-07-29 19:19:04 +02:00
|
|
|
from __future__ import unicode_literals
|
2011-10-13 18:04:12 +00:00
|
|
|
|
2010-09-12 20:04:21 +00:00
|
|
|
from django.http import Http404
|
2015-02-09 13:19:34 -05:00
|
|
|
from django.shortcuts import get_list_or_404, get_object_or_404
|
2010-09-12 20:04:21 +00:00
|
|
|
from django.test import TestCase
|
|
|
|
|
2015-02-09 13:19:34 -05:00
|
|
|
from .models import Article, Author
|
2010-09-12 20:04:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
class GetObjectOr404Tests(TestCase):
|
|
|
|
def test_get_object_or_404(self):
|
|
|
|
a1 = Author.objects.create(name="Brave Sir Robin")
|
|
|
|
a2 = Author.objects.create(name="Patsy")
|
|
|
|
|
|
|
|
# No Articles yet, so we should get a Http404 error.
|
|
|
|
self.assertRaises(Http404, get_object_or_404, Article, title="Foo")
|
|
|
|
|
|
|
|
article = Article.objects.create(title="Run away!")
|
|
|
|
article.authors = [a1, a2]
|
|
|
|
# get_object_or_404 can be passed a Model to query.
|
|
|
|
self.assertEqual(
|
|
|
|
get_object_or_404(Article, title__contains="Run"),
|
|
|
|
article
|
|
|
|
)
|
|
|
|
|
|
|
|
# We can also use the Article manager through an Author object.
|
|
|
|
self.assertEqual(
|
|
|
|
get_object_or_404(a1.article_set, title__contains="Run"),
|
|
|
|
article
|
|
|
|
)
|
|
|
|
|
|
|
|
# No articles containing "Camelot". This should raise a Http404 error.
|
2013-12-09 00:20:06 +07:00
|
|
|
self.assertRaises(
|
|
|
|
Http404,
|
2010-09-12 20:04:21 +00:00
|
|
|
get_object_or_404, a1.article_set, title__contains="Camelot"
|
|
|
|
)
|
|
|
|
|
|
|
|
# Custom managers can be used too.
|
|
|
|
self.assertEqual(
|
|
|
|
get_object_or_404(Article.by_a_sir, title="Run away!"),
|
|
|
|
article
|
|
|
|
)
|
|
|
|
|
|
|
|
# QuerySets can be used too.
|
|
|
|
self.assertEqual(
|
|
|
|
get_object_or_404(Article.objects.all(), title__contains="Run"),
|
|
|
|
article
|
|
|
|
)
|
|
|
|
|
|
|
|
# Just as when using a get() lookup, you will get an error if more than
|
|
|
|
# one object is returned.
|
|
|
|
|
2013-12-09 00:20:06 +07:00
|
|
|
self.assertRaises(
|
|
|
|
Author.MultipleObjectsReturned,
|
2010-09-12 20:04:21 +00:00
|
|
|
get_object_or_404, Author.objects.all()
|
|
|
|
)
|
|
|
|
|
2012-10-24 00:04:37 +03:00
|
|
|
# Using an empty QuerySet raises a Http404 error.
|
2013-12-09 00:20:06 +07:00
|
|
|
self.assertRaises(
|
|
|
|
Http404,
|
2010-09-12 20:04:21 +00:00
|
|
|
get_object_or_404, Article.objects.none(), title__contains="Run"
|
|
|
|
)
|
|
|
|
|
|
|
|
# get_list_or_404 can be used to get lists of objects
|
|
|
|
self.assertEqual(
|
|
|
|
get_list_or_404(a1.article_set, title__icontains="Run"),
|
|
|
|
[article]
|
|
|
|
)
|
|
|
|
|
|
|
|
# Http404 is returned if the list is empty.
|
2013-12-09 00:20:06 +07:00
|
|
|
self.assertRaises(
|
|
|
|
Http404,
|
2010-09-12 20:04:21 +00:00
|
|
|
get_list_or_404, a1.article_set, title__icontains="Shrubbery"
|
|
|
|
)
|
|
|
|
|
|
|
|
# Custom managers can be used too.
|
|
|
|
self.assertEqual(
|
|
|
|
get_list_or_404(Article.by_a_sir, title__icontains="Run"),
|
|
|
|
[article]
|
|
|
|
)
|
|
|
|
|
|
|
|
# QuerySets can be used too.
|
|
|
|
self.assertEqual(
|
|
|
|
get_list_or_404(Article.objects.all(), title__icontains="Run"),
|
|
|
|
[article]
|
|
|
|
)
|
2012-12-12 20:34:59 +01:00
|
|
|
|
|
|
|
def test_bad_class(self):
|
|
|
|
# Given an argument klass that is not a Model, Manager, or Queryset
|
|
|
|
# raises a helpful ValueError message
|
2013-12-09 00:20:06 +07:00
|
|
|
self.assertRaisesMessage(
|
|
|
|
ValueError,
|
2012-12-12 20:34:59 +01:00
|
|
|
"Object is of type 'str', but must be a Django Model, Manager, "
|
|
|
|
"or QuerySet",
|
2013-07-29 19:19:04 +02:00
|
|
|
get_object_or_404, str("Article"), title__icontains="Run"
|
2012-12-12 20:34:59 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
class CustomClass(object):
|
|
|
|
pass
|
|
|
|
|
2013-12-09 00:20:06 +07:00
|
|
|
self.assertRaisesMessage(
|
|
|
|
ValueError,
|
2012-12-12 20:34:59 +01:00
|
|
|
"Object is of type 'CustomClass', but must be a Django Model, "
|
|
|
|
"Manager, or QuerySet",
|
|
|
|
get_object_or_404, CustomClass, title__icontains="Run"
|
|
|
|
)
|
|
|
|
|
|
|
|
# Works for lists too
|
2013-12-09 00:20:06 +07:00
|
|
|
self.assertRaisesMessage(
|
|
|
|
ValueError,
|
2012-12-12 20:34:59 +01:00
|
|
|
"Object is of type 'list', but must be a Django Model, Manager, "
|
|
|
|
"or QuerySet",
|
|
|
|
get_list_or_404, [Article], title__icontains="Run"
|
|
|
|
)
|