diff options
| author | Greg Chapple <gregchapple1@gmail.com> | 2014-02-23 18:56:21 +0000 |
|---|---|---|
| committer | Baptiste Mispelon <bmispelon@gmail.com> | 2014-02-23 21:36:25 +0100 |
| commit | b1d10205ce0c4bb355e20bed6258b5264ed06cc5 (patch) | |
| tree | 560ca05be10af88b4fd9d06d0ddf66f9742367e9 /tests/admin_docs | |
| parent | 27e906971067707a5fd9f910fd33bf0884103b87 (diff) | |
Added tests for django.contrib.admindocs
Refs #22015
Diffstat (limited to 'tests/admin_docs')
| -rw-r--r-- | tests/admin_docs/models.py | 52 | ||||
| -rw-r--r-- | tests/admin_docs/tests.py | 109 |
2 files changed, 150 insertions, 11 deletions
diff --git a/tests/admin_docs/models.py b/tests/admin_docs/models.py new file mode 100644 index 0000000000..9b8f388f4e --- /dev/null +++ b/tests/admin_docs/models.py @@ -0,0 +1,52 @@ +""" +Models for testing various aspects of the djang.contrib.admindocs app +""" + +from django.db import models + + +class Company(models.Model): + name = models.CharField(max_length=200) + + +class Group(models.Model): + name = models.CharField(max_length=200) + + +class Family(models.Model): + last_name = models.CharField(max_length=200) + + +class Person(models.Model): + first_name = models.CharField(max_length=200, help_text="The person's first name") + last_name = models.CharField(max_length=200, help_text="The person's last name") + company = models.ForeignKey(Company, help_text="place of work") + family = models.ForeignKey(Family, related_name='+', null=True) + groups = models.ManyToManyField(Group, help_text="has membership") + + def _get_full_name(self): + return "%s %s" % (self.first_name, self.last_name) + + def add_image(self): + pass + + def delete_image(self): + pass + + def save_changes(self): + pass + + def set_status(self): + pass + + def get_full_name(self): + """ + Get the full name of the person + """ + return self._get_full_name() + + def get_status_count(self): + return 0 + + def get_groups_list(self): + return [] diff --git a/tests/admin_docs/tests.py b/tests/admin_docs/tests.py index e3f1460f4b..0f73e8dede 100644 --- a/tests/admin_docs/tests.py +++ b/tests/admin_docs/tests.py @@ -3,10 +3,13 @@ import unittest from django.conf import settings from django.contrib.sites.models import Site from django.contrib.admindocs import utils +from django.contrib.admindocs.views import get_return_data_type from django.contrib.auth.models import User from django.core.urlresolvers import reverse from django.test import TestCase, modify_settings, override_settings +from .models import Person, Company + class MiscTests(TestCase): urls = 'admin_docs.urls' @@ -80,17 +83,6 @@ class AdminDocViewTests(TestCase): response = self.client.get(reverse('django-admindocs-models-index')) self.assertContains(response, '<h2 id="app-auth">Auth</h2>', html=True) - def test_model_detail(self): - response = self.client.get(reverse('django-admindocs-models-detail', - args=['auth', 'user'])) - # Check for attribute, many-to-many field - self.assertContains(response, - '<tr><td>email</td><td>Email address</td><td>email address</td></tr>', html=True) - self.assertContains(response, - '<tr><td>user_permissions.all</td><td>List</td><td>' - '<p>all related <a class="reference external" href="/admindocs/models/auth.permission/">' - 'auth.Permission</a> objects</p></td></tr>', html=True) - def test_template_detail(self): response = self.client.get(reverse('django-admindocs-templates', args=['admin_doc/template_detail.html'])) @@ -189,3 +181,98 @@ class DefaultRoleTest(TestCase): markup = '<p>reST, <cite>interpreted text</cite>, default role.</p>\n' parts = docutils.core.publish_parts(source=source, writer_name="html4css1") self.assertEqual(parts['fragment'], markup) + + +@override_settings(PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',)) +@unittest.skipUnless(utils.docutils_is_available, "no docutils installed.") +class TestModelDetailView(TestCase): + """ + Tests that various details render correctly + """ + + fixtures = ['data.xml'] + urls = 'admin_docs.urls' + + def setUp(self): + self.client.login(username='super', password='secret') + self.response = self.client.get( + reverse('django-admindocs-models-detail', + args=['admin_docs', 'person'])) + + def test_method_excludes(self): + """ + Test that methods that begin with strings defined in + ``django.contrib.admindocs.views.MODEL_METHODS_EXCLUDE`` + do not get displayed in the admin docs + """ + self.assertContains(self.response, "<td>get_full_name</td>") + self.assertNotContains(self.response, "<td>_get_full_name</td>") + self.assertNotContains(self.response, "<td>add_image</td>") + self.assertNotContains(self.response, "<td>delete_image</td>") + self.assertNotContains(self.response, "<td>set_status</td>") + self.assertNotContains(self.response, "<td>save_changes</td>") + + def test_method_data_types(self): + """ + We should be able to get a basic idea of the type returned + by a method + """ + company = Company.objects.create(name="Django") + person = Person.objects.create( + first_name="Human", + last_name="User", + company=company + ) + + self.assertEqual( + get_return_data_type(person.get_status_count.__name__), + 'Integer' + ) + + self.assertEqual( + get_return_data_type(person.get_groups_list.__name__), + 'List' + ) + + def test_descriptions_render_correctly(self): + """ + The ``description`` field should render correctly for each type of field + """ + # help text in fields + self.assertContains(self.response, "<td>first name - The person's first name</td>") + self.assertContains(self.response, "<td>last name - The person's last name</td>") + + # method docstrings + self.assertContains(self.response, "<p>Get the full name of the person</p>") + + link = '<a class="reference external" href="/admindocs/models/%s/">%s</a>' + markup = '<p>the related %s object</p>' + company_markup = markup % (link % ("admin_docs.company", "admin_docs.Company")) + + # foreign keys + self.assertContains(self.response, company_markup) + + # foreign keys with help text + self.assertContains(self.response, "%s\n - place of work" % company_markup) + + # many to many fields + self.assertContains( + self.response, + "number of related %s objects" % (link % ("admin_docs.group", "admin_docs.Group")) + ) + self.assertContains( + self.response, + "all related %s objects" % (link % ("admin_docs.group", "admin_docs.Group")) + ) + + def test_model_with_no_backward_relations_render_only_relevant_fields(self): + """ + A model with ``related_name`` of `+` should not show backward relationship + links in admin docs + """ + response = self.client.get( + reverse('django-admindocs-models-detail', + args=['admin_docs', 'family'])) + + fields = response.context_data.get('fields') + self.assertEqual(len(fields), 2) |
