Update the entire with keyword arguments. Update the views to comply with MERC 6 by returning error 404 on access failure. API are untouched. Add icon to the ACL delete button. Add additional view tests. Use the new filtered choice form to display a select2 enabled role selection widget. Update the ACL creation view to not redirect to an existing ACL in case of duplication but to instead stop and display an error with a suggestion to the user to instead edit the existing ACL. Signed-off-by: Roberto Rosario <Roberto.Rosario@mayan-edms.com>
101 lines
3.2 KiB
Python
101 lines
3.2 KiB
Python
from __future__ import unicode_literals
|
|
|
|
from django.contrib.contenttypes.models import ContentType
|
|
from django.urls import reverse
|
|
|
|
from mayan.apps.documents.tests import GenericDocumentViewTestCase
|
|
|
|
from ..links import (
|
|
link_acl_create, link_acl_delete, link_acl_list, link_acl_permissions
|
|
)
|
|
from ..models import AccessControlList
|
|
from ..permissions import permission_acl_edit, permission_acl_view
|
|
|
|
|
|
class ACLsLinksTestCase(GenericDocumentViewTestCase):
|
|
def test_document_acl_create_link(self):
|
|
acl = AccessControlList.objects.create(
|
|
content_object=self.document, role=self.role
|
|
)
|
|
|
|
acl.permissions.add(permission_acl_edit.stored_permission)
|
|
self.login_user()
|
|
|
|
self.add_test_view(test_object=self.document)
|
|
context = self.get_test_view()
|
|
resolved_link = link_acl_create.resolve(context=context)
|
|
|
|
self.assertNotEqual(resolved_link, None)
|
|
|
|
content_type = ContentType.objects.get_for_model(self.document)
|
|
kwargs = {
|
|
'app_label': content_type.app_label,
|
|
'model': content_type.model,
|
|
'object_id': self.document.pk
|
|
}
|
|
|
|
self.assertEqual(
|
|
resolved_link.url, reverse(viewname='acls:acl_create', kwargs=kwargs)
|
|
)
|
|
|
|
def test_document_acl_delete_link(self):
|
|
acl = AccessControlList.objects.create(
|
|
content_object=self.document, role=self.role
|
|
)
|
|
|
|
acl.permissions.add(permission_acl_edit.stored_permission)
|
|
self.login_user()
|
|
|
|
self.add_test_view(test_object=acl)
|
|
context = self.get_test_view()
|
|
resolved_link = link_acl_delete.resolve(context=context)
|
|
|
|
self.assertNotEqual(resolved_link, None)
|
|
|
|
self.assertEqual(
|
|
resolved_link.url, reverse(viewname='acls:acl_delete', kwargs={'acl_pk': acl.pk})
|
|
)
|
|
|
|
def test_document_acl_edit_link(self):
|
|
acl = AccessControlList.objects.create(
|
|
content_object=self.document, role=self.role
|
|
)
|
|
|
|
acl.permissions.add(permission_acl_edit.stored_permission)
|
|
self.login_user()
|
|
|
|
self.add_test_view(test_object=acl)
|
|
context = self.get_test_view()
|
|
resolved_link = link_acl_permissions.resolve(context=context)
|
|
|
|
self.assertNotEqual(resolved_link, None)
|
|
|
|
self.assertEqual(
|
|
resolved_link.url, reverse(viewname='acls:acl_permissions', kwargs={'acl_pk': acl.pk})
|
|
)
|
|
|
|
def test_document_acl_list_link(self):
|
|
acl = AccessControlList.objects.create(
|
|
content_object=self.document, role=self.role
|
|
)
|
|
|
|
acl.permissions.add(permission_acl_view.stored_permission)
|
|
self.login_user()
|
|
|
|
self.add_test_view(test_object=self.document)
|
|
context = self.get_test_view()
|
|
resolved_link = link_acl_list.resolve(context=context)
|
|
|
|
self.assertNotEqual(resolved_link, None)
|
|
|
|
content_type = ContentType.objects.get_for_model(self.document)
|
|
kwargs = {
|
|
'app_label': content_type.app_label,
|
|
'model': content_type.model,
|
|
'object_id': self.document.pk
|
|
}
|
|
|
|
self.assertEqual(
|
|
resolved_link.url, reverse(viewname='acls:acl_list', kwargs=kwargs)
|
|
)
|