diff --git a/contrib/sample_documents/I18N_title_áéíóúüñÑ.png b/contrib/sample_documents/I18N_title_áéíóúüñÑ.png new file mode 100644 index 0000000000..ece2f481d6 Binary files /dev/null and b/contrib/sample_documents/I18N_title_áéíóúüñÑ.png differ diff --git a/mayan/apps/documents/tests.py b/mayan/apps/documents/tests.py index 2a90c24947..0b9f4e6996 100644 --- a/mayan/apps/documents/tests.py +++ b/mayan/apps/documents/tests.py @@ -1,3 +1,5 @@ +# -*- coding: utf-8 -*- + from __future__ import unicode_literals from json import loads @@ -19,9 +21,11 @@ TEST_ADMIN_PASSWORD = 'test_admin_password' TEST_ADMIN_USERNAME = 'test_admin' TEST_ADMIN_EMAIL = 'admin@admin.com' TEST_SMALL_DOCUMENT_FILENAME = 'title_page.png' +TEST_NON_ASCII_DOCUMENT_FILENAME = 'I18N_title_áéíóúüñÑ.png' TEST_DOCUMENT_PATH = os.path.join(settings.BASE_DIR, 'contrib', 'sample_documents', 'mayan_11_1.pdf') TEST_SIGNED_DOCUMENT_PATH = os.path.join(settings.BASE_DIR, 'contrib', 'sample_documents', 'mayan_11_1.pdf.gpg') TEST_SMALL_DOCUMENT_PATH = os.path.join(settings.BASE_DIR, 'contrib', 'sample_documents', TEST_SMALL_DOCUMENT_FILENAME) +TEST_NON_ASCII_DOCUMENT_PATH = os.path.join(settings.BASE_DIR, 'contrib', 'sample_documents', TEST_NON_ASCII_DOCUMENT_FILENAME) TEST_DOCUMENT_DESCRIPTION = 'test description' TEST_DOCUMENT_TYPE = 'test_document_type' diff --git a/mayan/apps/sources/tests.py b/mayan/apps/sources/tests.py index 97505e167b..9e4d14c89e 100644 --- a/mayan/apps/sources/tests.py +++ b/mayan/apps/sources/tests.py @@ -1,5 +1,8 @@ from __future__ import unicode_literals +import shutil +import tempfile + from django.contrib.auth.models import User from django.core.urlresolvers import reverse from django.test.client import Client @@ -11,11 +14,13 @@ from sources.models import WebFormSource from documents.tests import ( TEST_ADMIN_PASSWORD, TEST_ADMIN_USERNAME, TEST_ADMIN_EMAIL, - TEST_SMALL_DOCUMENT_FILENAME, TEST_DOCUMENT_PATH, - TEST_SIGNED_DOCUMENT_PATH, TEST_SMALL_DOCUMENT_PATH, - TEST_DOCUMENT_DESCRIPTION, TEST_DOCUMENT_TYPE + TEST_DOCUMENT_PATH, TEST_SMALL_DOCUMENT_PATH, + TEST_DOCUMENT_DESCRIPTION, TEST_DOCUMENT_TYPE, + TEST_NON_ASCII_DOCUMENT_FILENAME, TEST_NON_ASCII_DOCUMENT_PATH ) +from .models import WatchFolderSource + class UploadDocumentTestCase(TestCase): """ @@ -23,10 +28,36 @@ class UploadDocumentTestCase(TestCase): """ def setUp(self): - self.document_type = DocumentType.objects.create(name='test doc type') + self.document_type = DocumentType.objects.create(name=TEST_DOCUMENT_TYPE) self.admin_user = User.objects.create_superuser(username=TEST_ADMIN_USERNAME, email=TEST_ADMIN_EMAIL, password=TEST_ADMIN_PASSWORD) self.client = Client() + def test_issue_gh_163(self): + """ + Non-ASCII chars in document name failing in upload via watch folder #163 + https://github.com/mayan-edms/mayan-edms/issues/163 + """ + + temporary_directory = tempfile.mkdtemp() + shutil.copy(TEST_NON_ASCII_DOCUMENT_PATH, temporary_directory) + + watch_folder = WatchFolderSource.objects.create(document_type=self.document_type, folder_path=temporary_directory, uncompress=False) + watch_folder.check_source() + + self.assertEqual(Document.objects.count(), 1) + + document = Document.objects.first() + + self.failUnlessEqual(document.exists(), True) + self.failUnlessEqual(document.size, 17436) + + self.failUnlessEqual(document.file_mimetype, 'image/png') + self.failUnlessEqual(document.file_mime_encoding, 'binary') + self.failUnlessEqual(document.label, TEST_NON_ASCII_DOCUMENT_FILENAME) + self.failUnlessEqual(document.page_count, 1) + + shutil.rmtree(temporary_directory) + def test_upload_a_document(self): # Login the admin user logged_in = self.client.login(username=TEST_ADMIN_USERNAME, password=TEST_ADMIN_PASSWORD)