Fix document check in view. Fixes issue GH#238.
This commit is contained in:
95
mayan/apps/checkouts/tests/test_views.py
Normal file
95
mayan/apps/checkouts/tests/test_views.py
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
import datetime
|
||||||
|
import time
|
||||||
|
|
||||||
|
from django.contrib.auth.models import User
|
||||||
|
from django.core.files import File
|
||||||
|
from django.core.urlresolvers import reverse
|
||||||
|
from django.test.client import Client
|
||||||
|
from django.test import TestCase
|
||||||
|
from django.utils.timezone import now
|
||||||
|
|
||||||
|
from common.literals import TIME_DELTA_UNIT_DAYS
|
||||||
|
from documents.models import DocumentType
|
||||||
|
from documents.tests.literals import (
|
||||||
|
TEST_ADMIN_PASSWORD, TEST_ADMIN_USERNAME, TEST_ADMIN_EMAIL,
|
||||||
|
TEST_DOCUMENT_TYPE, TEST_SMALL_DOCUMENT_PATH
|
||||||
|
)
|
||||||
|
|
||||||
|
from ..models import DocumentCheckout
|
||||||
|
|
||||||
|
|
||||||
|
class DocumentCheckoutViewTestCase(TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
self.admin_user = User.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())
|
||||||
|
|
||||||
|
self.document_type = DocumentType.objects.create(
|
||||||
|
label=TEST_DOCUMENT_TYPE
|
||||||
|
)
|
||||||
|
|
||||||
|
with open(TEST_SMALL_DOCUMENT_PATH) as file_object:
|
||||||
|
self.document = self.document_type.new_document(
|
||||||
|
file_object=File(file_object)
|
||||||
|
)
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
self.document_type.delete()
|
||||||
|
self.admin_user.delete()
|
||||||
|
|
||||||
|
def test_checkout_view(self):
|
||||||
|
response = self.client.post(
|
||||||
|
reverse(
|
||||||
|
'checkouts:checkout_document', args=(self.document.pk,),
|
||||||
|
), data={
|
||||||
|
'expiration_datetime_0': 2,
|
||||||
|
'expiration_datetime_1': TIME_DELTA_UNIT_DAYS,
|
||||||
|
'block_new_version': True
|
||||||
|
}, follow=True
|
||||||
|
)
|
||||||
|
|
||||||
|
self.assertEquals(response.status_code, 200)
|
||||||
|
|
||||||
|
self.assertTrue(self.document.is_checked_out())
|
||||||
|
|
||||||
|
self.assertTrue(
|
||||||
|
DocumentCheckout.objects.is_document_checked_out(
|
||||||
|
document=self.document
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_checkin_view(self):
|
||||||
|
expiration_datetime = now() + datetime.timedelta(days=1)
|
||||||
|
|
||||||
|
DocumentCheckout.objects.checkout_document(
|
||||||
|
document=self.document, expiration_datetime=expiration_datetime,
|
||||||
|
user=self.admin_user, block_new_version=True
|
||||||
|
)
|
||||||
|
|
||||||
|
self.assertTrue(self.document.is_checked_out())
|
||||||
|
|
||||||
|
response = self.client.post(
|
||||||
|
reverse(
|
||||||
|
'checkouts:checkin_document', args=(self.document.pk,),
|
||||||
|
), follow=True
|
||||||
|
)
|
||||||
|
|
||||||
|
self.assertEquals(response.status_code, 200)
|
||||||
|
|
||||||
|
self.assertFalse(self.document.is_checked_out())
|
||||||
|
|
||||||
|
self.assertFalse(
|
||||||
|
DocumentCheckout.objects.is_document_checked_out(
|
||||||
|
document=self.document
|
||||||
|
)
|
||||||
|
)
|
||||||
@@ -181,38 +181,38 @@ class DocumentCheckinView(ConfirmView):
|
|||||||
def get_post_action_redirect(self):
|
def get_post_action_redirect(self):
|
||||||
return reverse('checkouts:checkout_info', args=(self.get_object().pk,))
|
return reverse('checkouts:checkout_info', args=(self.get_object().pk,))
|
||||||
|
|
||||||
def view_action(self, request):
|
def view_action(self):
|
||||||
document = self.get_object()
|
document = self.get_object()
|
||||||
|
|
||||||
if document.checkout_info().user == request.user:
|
if document.checkout_info().user == self.request.user:
|
||||||
try:
|
try:
|
||||||
Permission.check_permissions(
|
Permission.check_permissions(
|
||||||
request.user, (permission_document_checkin,)
|
self.request.user, (permission_document_checkin,)
|
||||||
)
|
)
|
||||||
except PermissionDenied:
|
except PermissionDenied:
|
||||||
AccessControlList.objects.check_access(
|
AccessControlList.objects.check_access(
|
||||||
permission_document_checkin, request.user, document
|
permission_document_checkin, self.request.user, document
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
try:
|
try:
|
||||||
Permission.check_permissions(
|
Permission.check_permissions(
|
||||||
request.user, (permission_document_checkin_override,)
|
self.request.user, (permission_document_checkin_override,)
|
||||||
)
|
)
|
||||||
except PermissionDenied:
|
except PermissionDenied:
|
||||||
AccessControlList.objects.check_access(
|
AccessControlList.objects.check_access(
|
||||||
permission_document_checkin_override, request.user,
|
permission_document_checkin_override, self.request.user,
|
||||||
document
|
document
|
||||||
)
|
)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
document.check_in(user=request.user)
|
document.check_in(user=self.request.user)
|
||||||
except DocumentNotCheckedOut:
|
except DocumentNotCheckedOut:
|
||||||
messages.error(request, _('Document has not been checked out.'))
|
messages.error(self.request, _('Document has not been checked out.'))
|
||||||
except Exception as exception:
|
except Exception as exception:
|
||||||
messages.error(
|
messages.error(
|
||||||
request, _('Error trying to check in document; %s') % exception
|
self.request, _('Error trying to check in document; %s') % exception
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
messages.success(
|
messages.success(
|
||||||
request, _('Document "%s" checked in successfully.') % document
|
self.request, _('Document "%s" checked in successfully.') % document
|
||||||
)
|
)
|
||||||
|
|||||||
Reference in New Issue
Block a user