Add permissions app views tests.

This commit is contained in:
Roberto Rosario
2015-10-15 19:37:04 -04:00
parent 8744bd82ee
commit 90a1ecb826
3 changed files with 82 additions and 4 deletions

View File

@@ -1,6 +1,7 @@
from __future__ import unicode_literals
TEST_GROUP = 'test group'
TEST_ROLE = 'test role'
TEST_ROLE_LABEL = 'test role'
TEST_ROLE_LABEL_EDITED = 'test role label edited'
TEST_USER_USERNAME = 'test user'
TEST_USER_PASSWORD = 'test password'

View File

@@ -9,14 +9,16 @@ from ..classes import Permission
from ..models import Role
from ..permissions import permission_role_view
from .literals import TEST_GROUP, TEST_ROLE, TEST_USER_USERNAME
from .literals import TEST_GROUP, TEST_ROLE_LABEL, TEST_USER_USERNAME
class PermissionTestCase(TestCase):
def setUp(self):
self.user = get_user_model().objects.create(username=TEST_USER_USERNAME)
self.user = get_user_model().objects.create(
username=TEST_USER_USERNAME
)
self.group = Group.objects.create(name=TEST_GROUP)
self.role = Role.objects.create(label=TEST_ROLE)
self.role = Role.objects.create(label=TEST_ROLE_LABEL)
Permission.invalidate_cache()
def tearDown(self):

View File

@@ -0,0 +1,75 @@
from __future__ import unicode_literals
from django.contrib.auth import get_user_model
from django.core.urlresolvers import reverse
from django.test.client import Client
from django.test import TestCase
from documents.tests.literals import (
TEST_ADMIN_PASSWORD, TEST_ADMIN_USERNAME, TEST_ADMIN_EMAIL
)
from ..models import Role
from .literals import TEST_ROLE_LABEL, TEST_ROLE_LABEL_EDITED
class PermissionsViewsTestCase(TestCase):
def setUp(self):
self.admin_user = get_user_model().objects.create_superuser(
username=TEST_ADMIN_USERNAME, email=TEST_ADMIN_EMAIL,
password=TEST_ADMIN_PASSWORD
)
self.client = Client()
# Login the admin user
logged_in = self.client.login(
username=TEST_ADMIN_USERNAME, password=TEST_ADMIN_PASSWORD
)
self.assertTrue(logged_in)
self.assertTrue(self.admin_user.is_authenticated())
def tearDown(self):
self.admin_user.delete()
def test_role_creation_view(self):
response = self.client.post(
reverse(
'permissions:role_create',
), data={
'label': TEST_ROLE_LABEL,
}, follow=True
)
self.assertContains(response, 'created', status_code=200)
self.assertEqual(Role.objects.count(), 1)
self.assertEqual(Role.objects.first().label, TEST_ROLE_LABEL)
def test_role_delete_view(self):
role = Role.objects.create(label=TEST_ROLE_LABEL)
response = self.client.post(
reverse(
'permissions:role_delete', args=(role.pk,),
), follow=True
)
self.assertContains(response, 'deleted', status_code=200)
self.assertEqual(Role.objects.count(), 0)
def test_role_edit_view(self):
role = Role.objects.create(label=TEST_ROLE_LABEL)
response = self.client.post(
reverse(
'permissions:role_edit', args=(role.pk,),
), data={
'label': TEST_ROLE_LABEL_EDITED,
}, follow=True
)
self.assertContains(response, 'saved', status_code=200)
self.assertEqual(Role.objects.count(), 1)
self.assertEqual(Role.objects.first().label, TEST_ROLE_LABEL_EDITED)