Add folder app view tests.

This commit is contained in:
Roberto Rosario
2015-10-17 02:17:36 -04:00
parent 480a107c61
commit 6e9c2a14ae
4 changed files with 185 additions and 25 deletions

View File

@@ -0,0 +1,4 @@
from __future__ import absolute_import, unicode_literals
TEST_FOLDER_LABEL = 'test folder label'
TEST_FOLDER_EDITED_LABEL = 'test folder edited label'

View File

@@ -50,7 +50,9 @@ class FolderAPITestCase(APITestCase):
label=TEST_FOLDER_LABEL, user=self.admin_user
)
self.client.delete(reverse('rest_api:folder-detail', args=(folder.pk,)))
self.client.delete(
reverse('rest_api:folder-detail', args=(folder.pk,))
)
self.assertEqual(Folder.objects.count(), 0)
@@ -70,7 +72,9 @@ class FolderAPITestCase(APITestCase):
@override_settings(OCR_AUTO_OCR=False)
def test_folder_add_document(self):
folder = Folder.objects.create(label=TEST_FOLDER_LABEL, user=self.admin_user)
folder = Folder.objects.create(
label=TEST_FOLDER_LABEL, user=self.admin_user
)
document_type = DocumentType.objects.create(
label=TEST_DOCUMENT_TYPE
@@ -90,7 +94,9 @@ class FolderAPITestCase(APITestCase):
@override_settings(OCR_AUTO_OCR=False)
def test_folder_remove_document(self):
folder = Folder.objects.create(label=TEST_FOLDER_LABEL, user=self.admin_user)
folder = Folder.objects.create(
label=TEST_FOLDER_LABEL, user=self.admin_user
)
document_type = DocumentType.objects.create(
label=TEST_DOCUMENT_TYPE

View File

@@ -0,0 +1,145 @@
from __future__ import absolute_import, unicode_literals
from django.contrib.auth import get_user_model
from django.core.files import File
from django.core.urlresolvers import reverse
from django.test.client import Client
from django.test import TestCase
from documents.models import DocumentType
from documents.tests import (
TEST_ADMIN_PASSWORD, TEST_ADMIN_USERNAME, TEST_ADMIN_EMAIL,
TEST_DOCUMENT_TYPE, TEST_SMALL_DOCUMENT_PATH
)
from ..models import Folder
from .literals import TEST_FOLDER_LABEL, TEST_FOLDER_EDITED_LABEL
class FolderViewTestCase(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.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)
)
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()
self.document_type
def test_folder_create_view(self):
response = self.client.post(
reverse('folders:folder_create'), data={
'label': TEST_FOLDER_LABEL
}, follow=True
)
self.assertContains(response, text='created', status_code=200)
self.assertEqual(Folder.objects.count(), 1)
self.assertEqual(Folder.objects.first().label, TEST_FOLDER_LABEL)
self.assertEqual(Folder.objects.first().user, self.admin_user)
def test_folder_delete_view(self):
folder = Folder.objects.create(
label=TEST_FOLDER_LABEL, user=self.admin_user
)
response = self.client.post(
reverse('folders:folder_delete', args=(folder.pk,)), follow=True
)
self.assertContains(response, text='deleted', status_code=200)
self.assertEqual(Folder.objects.count(), 0)
def test_folder_edit_view(self):
folder = Folder.objects.create(
label=TEST_FOLDER_LABEL, user=self.admin_user
)
response = self.client.post(
reverse('folders:folder_edit', args=(folder.pk,)), data = {
'label': TEST_FOLDER_EDITED_LABEL
}, follow=True
)
folder = Folder.objects.get(pk=folder.pk)
self.assertContains(response, text='saved', status_code=200)
self.assertEqual(folder.label, TEST_FOLDER_EDITED_LABEL)
self.assertEqual(folder.user, self.admin_user)
def test_folder_add_document_view(self):
folder = Folder.objects.create(
label=TEST_FOLDER_LABEL, user=self.admin_user
)
response = self.client.post(
reverse('folders:folder_add_document', args=(self.document.pk,)),
data={
'folder': folder.pk,
}, follow=True
)
folder = Folder.objects.get(pk=folder.pk)
self.assertContains(response, text='added', status_code=200)
self.assertEqual(folder.documents.count(), 1)
self.assertQuerysetEqual(
folder.documents.all(), (repr(self.document),)
)
def test_folder_add_multiple_documents_view(self):
folder = Folder.objects.create(
label=TEST_FOLDER_LABEL, user=self.admin_user
)
response = self.client.post(
reverse('folders:folder_add_multiple_documents'), data={
'id_list': (self.document.pk,),
'folder': folder.pk
}, follow=True
)
folder = Folder.objects.get(pk=folder.pk)
self.assertContains(response, text='added', status_code=200)
self.assertEqual(folder.documents.count(), 1)
self.assertQuerysetEqual(
folder.documents.all(), (repr(self.document),)
)
def test_folder_remove_document_view(self):
folder = Folder.objects.create(
label=TEST_FOLDER_LABEL, user=self.admin_user,
)
folder.documents.add(self.document)
self.assertEqual(folder.documents.count(), 1)
response = self.client.post(
reverse(
'folders:folder_document_multiple_remove', args=(folder.pk,)
), data={
'id_list': (self.document.pk,),
}, follow=True
)
folder = Folder.objects.get(pk=folder.pk)
self.assertContains(response, text='removed', status_code=200)
self.assertEqual(folder.documents.count(), 0)

View File

@@ -124,11 +124,23 @@ def folder_delete(request, folder_id):
'title': _('Delete the folder: %s?') % folder,
}
return render_to_response('appearance/generic_confirm.html', context,
context_instance=RequestContext(request))
return render_to_response(
'appearance/generic_confirm.html', context,
context_instance=RequestContext(request)
)
class FolderDetailView(DocumentListView):
def get_document_queryset(self):
return self.get_folder().documents.all()
def get_extra_context(self):
return {
'title': _('Documents in folder: %s') % self.get_folder(),
'hide_links': True,
'object': self.get_folder(),
}
def get_folder(self):
folder = get_object_or_404(Folder, pk=self.kwargs['pk'])
@@ -143,19 +155,8 @@ class FolderDetailView(DocumentListView):
return folder
def get_document_queryset(self):
return self.get_folder().documents.all()
def get_extra_context(self):
return {
'title': _('Documents in folder: %s') % self.get_folder(),
'hide_links': True,
'object': self.get_folder(),
}
def folder_add_document(request, document_id=None, document_id_list=None):
if document_id:
documents = [get_object_or_404(Document, pk=document_id)]
elif document_id_list:
@@ -208,8 +209,10 @@ def folder_add_document(request, document_id=None, document_id_list=None):
len(documents)
)
return render_to_response('appearance/generic_form.html', context,
context_instance=RequestContext(request))
return render_to_response(
'appearance/generic_form.html', context,
context_instance=RequestContext(request)
)
class DocumentFolderListView(FolderListView):
@@ -227,9 +230,6 @@ class DocumentFolderListView(FolderListView):
return super(DocumentFolderListView, self).dispatch(request, *args, **kwargs)
def get_folder_queryset(self):
return self.document.document_folders().all()
def get_extra_context(self):
return {
'hide_link': True,
@@ -237,6 +237,9 @@ class DocumentFolderListView(FolderListView):
'title': _('Folders containing document: %s') % self.document,
}
def get_folder_queryset(self):
return self.document.document_folders().all()
def folder_document_remove(request, folder_id, document_id=None, document_id_list=None):
post_action_redirect = None
@@ -287,15 +290,17 @@ def folder_document_remove(request, folder_id, document_id=None, document_id_lis
if len(folder_documents) == 1:
context['object'] = folder_documents[0]
return render_to_response('appearance/generic_confirm.html', context,
context_instance=RequestContext(request))
return render_to_response(
'appearance/generic_confirm.html', context,
context_instance=RequestContext(request)
)
def folder_document_multiple_remove(request, folder_id):
return folder_document_remove(request, folder_id, document_id_list=request.GET.get('id_list', []))
return folder_document_remove(request, folder_id, document_id_list=request.GET.get('id_list', request.POST.get('id_list', [])))
def folder_add_multiple_documents(request):
return folder_add_document(
request, document_id_list=request.GET.get('id_list', [])
request, document_id_list=request.GET.get('id_list', request.POST.get('id_list', []))
)