X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/9c5d9a4e77a10b4e60d89d3890e49002bd7f3993..a3ec7115f15e57fec50c96ccebcd4e6b13e130b6:/apps/catalogue/test_utils.py?ds=inline diff --git a/apps/catalogue/test_utils.py b/apps/catalogue/test_utils.py index 3a8af57aa..101a508b8 100644 --- a/apps/catalogue/test_utils.py +++ b/apps/catalogue/test_utils.py @@ -1,18 +1,33 @@ -from django.conf import settings -from django.test import TestCase -import shutil +# -*- coding: utf-8 -*- +# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later. +# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. +# +from os.path import abspath, dirname, join import tempfile +from traceback import extract_stack +from django.test import TestCase +from django.test.utils import override_settings +from fnpdjango.utils.text.slughifi import slughifi +from librarian import WLURI +from django.conf import settings + +@override_settings( + MEDIA_ROOT=tempfile.mkdtemp(prefix='djangotest_'), + CATALOGUE_DONT_BUILD=set(['pdf', 'mobi', 'epub', 'txt', 'fb2', 'cover']), + NO_SEARCH_INDEX=True, + CELERY_ALWAYS_EAGER=True, + CACHES={ + 'default': {'BACKEND': 'django.core.cache.backends.dummy.DummyCache'}, + }, + SOLR=settings.SOLR_TEST, +) class WLTestCase(TestCase): """ Generic base class for tests. Adds settings freeze and clears MEDIA_ROOT. """ - def setUp(self): - self._MEDIA_ROOT, settings.MEDIA_ROOT = settings.MEDIA_ROOT, tempfile.mkdtemp(prefix='djangotest_') + longMessage = True - def tearDown(self): - shutil.rmtree(settings.MEDIA_ROOT, True) - settings.MEDIA_ROOT = self._MEDIA_ROOT class PersonStub(object): @@ -20,8 +35,16 @@ class PersonStub(object): self.first_names = first_names self.last_name = last_name + def readable(self): + return " ".join(self.first_names + (self.last_name,)) + class BookInfoStub(object): + _empty_fields = ['cover_url', 'variant_of'] + # allow single definition for multiple-value fields + _salias = { + 'authors': 'author', + } def __init__(self, **kwargs): self.__dict = kwargs @@ -32,7 +55,38 @@ class BookInfoStub(object): return object.__setattr__(self, key, value) def __getattr__(self, key): - return self.__dict[key] + try: + return self.__dict[key] + except KeyError: + if key in self._empty_fields: + return None + elif key in self._salias: + return [getattr(self, self._salias[key])] + else: + raise def to_dict(self): return dict((key, unicode(value)) for key, value in self.__dict.items()) + + +def info_args(title, language=None): + """ generate some keywords for comfortable BookInfoCreation """ + slug = unicode(slughifi(title)) + if language is None: + language = u'pol' + return { + 'title': unicode(title), + 'url': WLURI.from_slug(slug), + 'about': u"http://wolnelektury.pl/example/URI/%s" % slug, + 'language': language, + } + + +def get_fixture(path, app=None): + if app is not None: + mod_path = app.__file__ + f_path = join(dirname(abspath(mod_path)), 'tests/files', path) + else: + mod_path = extract_stack(limit=2)[0][0] + f_path = join(dirname(abspath(mod_path)), 'files', path) + return f_path