Files
mayan-edms/mayan/apps/permissions/tests/test_views.py

76 lines
2.2 KiB
Python

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 user_management.tests 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)