Speed up tests.

Signed-off-by: Roberto Rosario <roberto.rosario.gonzalez@gmail.com>
This commit is contained in:
Roberto Rosario
2018-08-23 00:17:53 -04:00
parent d6fd1b66c6
commit 48e7b7970c
4 changed files with 43 additions and 15 deletions

View File

@@ -104,14 +104,14 @@ class DocumentCheckoutTestCase(BaseTestCase):
self.document.check_in()
def test_auto_checkin(self):
expiration_datetime = now() + datetime.timedelta(seconds=1)
expiration_datetime = now() + datetime.timedelta(seconds=.1)
DocumentCheckout.objects.checkout_document(
document=self.document, expiration_datetime=expiration_datetime,
user=self.admin_user, block_new_version=True
)
time.sleep(2)
time.sleep(.11)
DocumentCheckout.objects.check_in_expired_check_outs()

View File

@@ -240,7 +240,7 @@ class DocumentSignaturesTestCase(BaseTestCase):
# Artifical delay since MySQL doesn't store microsecond data in
# timestamps. Version timestamp is used to determine which version
# is the latest.
time.sleep(2)
time.sleep(1)
self.assertEqual(EmbeddedSignature.objects.count(), 1)
@@ -264,8 +264,8 @@ class EmbeddedSignaturesTestCase(BaseTestCase):
super(EmbeddedSignaturesTestCase, self).tearDown()
def test_unsigned_document_version_method(self):
TEST_UNSIGNED_DOCUMENT_COUNT = 3
TEST_SIGNED_DOCUMENT_COUNT = 3
TEST_UNSIGNED_DOCUMENT_COUNT = 2
TEST_SIGNED_DOCUMENT_COUNT = 2
for count in range(TEST_UNSIGNED_DOCUMENT_COUNT):
with open(TEST_DOCUMENT_PATH) as file_object:
@@ -292,7 +292,7 @@ class EmbeddedSignaturesTestCase(BaseTestCase):
DocumentVersion._post_save_hooks = {}
TEST_UNSIGNED_DOCUMENT_COUNT = 4
TEST_UNSIGNED_DOCUMENT_COUNT = 2
TEST_SIGNED_DOCUMENT_COUNT = 2
for count in range(TEST_UNSIGNED_DOCUMENT_COUNT):

View File

@@ -102,7 +102,7 @@ class DocumentTestCase(BaseTestCase):
# Needed by MySQL as milliseconds value is not store in timestamp
# field
time.sleep(2)
time.sleep(1.01)
self.assertEqual(Document.objects.count(), 1)
self.assertEqual(DeletedDocument.objects.count(), 0)
@@ -130,9 +130,9 @@ class DocumentTestCase(BaseTestCase):
self.assertEqual(Document.objects.count(), 0)
self.assertEqual(DeletedDocument.objects.count(), 1)
# Needed by MySQL as milliseconds value is not store in timestamp
# Needed by MySQL as milliseconds value is not stored in timestamp
# field
time.sleep(2)
time.sleep(1.01)
DocumentType.objects.check_delete_periods()
@@ -235,7 +235,7 @@ class DocumentVersionTestCase(GenericDocumentTestCase):
# Needed by MySQL as milliseconds value is not store in timestamp
# field
time.sleep(2)
time.sleep(1.01)
with open(TEST_DOCUMENT_PATH) as file_object:
self.document.new_version(

View File

@@ -10,15 +10,43 @@ INSTALLED_APPS = [
COMMON_PRODUCTION_ERROR_LOG_PATH = '/tmp/mayan-errors.log'
TEMPLATES[0]['OPTIONS']['loaders'] = (
'django.template.loaders.filesystem.Loader',
'django.template.loaders.app_directories.Loader',
)
# Remove whitenoise from middlewares. Causes out of memory errors during test
# suit
MIDDLEWARE_CLASSES = [
cls for cls in MIDDLEWARE_CLASSES if cls != 'whitenoise.middleware.WhiteNoiseMiddleware'
]
# User a simpler password hasher
PASSWORD_HASHERS = (
'django.contrib.auth.hashers.MD5PasswordHasher',
)
STATICFILES_STORAGE = None
# Cache templates in memory
TEMPLATES[0]['OPTIONS']['loaders'] = (
(
'django.template.loaders.cached.Loader', (
'django.template.loaders.filesystem.Loader',
'django.template.loaders.app_directories.Loader',
)
),
)
CELERY_ALWAYS_EAGER = True
CELERY_EAGER_PROPAGATES_EXCEPTIONS = True
BROKER_BACKEND = 'memory'
# Remove middlewares not used for tests
MIDDLEWARE_CLASSES = [
cls for cls in MIDDLEWARE_CLASSES if cls not in [
'common.middleware.error_logging.ErrorLoggingMiddleware',
'django.middleware.security.SecurityMiddleware',
'corsheaders.middleware.CorsMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'django.middleware.locale.LocaleMiddleware',
'common.middleware.timezone.TimezoneMiddleware',
'common.middleware.ajax_redirect.AjaxRedirect',
]
]