gallery.accords-library.com/server/szurubooru/tests/conftest.py

200 lines
5.2 KiB
Python
Raw Normal View History

# pylint: disable=redefined-outer-name
import contextlib
2016-04-30 21:17:08 +00:00
import os
import random
import string
from datetime import datetime
2016-04-15 12:36:00 +00:00
import pytest
import freezegun
2016-04-15 12:36:00 +00:00
import sqlalchemy
from szurubooru import config, db, rest
2016-04-15 12:36:00 +00:00
class QueryCounter(object):
def __init__(self):
self._statements = []
def __enter__(self):
self._statements = []
def __exit__(self, *args, **kwargs):
self._statements = []
def create_before_cursor_execute(self):
def before_cursor_execute(
_conn, _cursor, statement, _params, _context, _executemany):
self._statements.append(statement)
return before_cursor_execute
@property
def statements(self):
return self._statements
if not config.config['test_database']:
raise RuntimeError('Test database not configured.')
_query_counter = QueryCounter()
_engine = sqlalchemy.create_engine(config.config['test_database'])
db.Base.metadata.drop_all(bind=_engine)
db.Base.metadata.create_all(bind=_engine)
sqlalchemy.event.listen(
_engine,
'before_cursor_execute',
_query_counter.create_before_cursor_execute())
def get_unique_name():
alphabet = string.ascii_letters + string.digits
return ''.join(random.choice(alphabet) for _ in range(8))
2016-04-16 08:57:42 +00:00
@pytest.fixture
def fake_datetime():
@contextlib.contextmanager
2016-04-16 08:57:42 +00:00
def injector(now):
2016-04-18 20:41:39 +00:00
freezer = freezegun.freeze_time(now)
freezer.start()
yield
freezer.stop()
2016-04-16 08:57:42 +00:00
return injector
@pytest.fixture()
def query_counter():
return _query_counter
@pytest.fixture
def query_logger():
if pytest.config.option.verbose > 0:
import logging
2016-05-11 20:08:10 +00:00
import coloredlogs
coloredlogs.install(
fmt='[%(asctime)-15s] %(name)s %(message)s', isatty=True)
logging.basicConfig()
logging.getLogger('sqlalchemy.engine').setLevel(logging.INFO)
@pytest.yield_fixture(scope='function', autouse=True)
def session(query_logger): # pylint: disable=unused-argument
db.sessionmaker = sqlalchemy.orm.sessionmaker(bind=_engine)
db.session = sqlalchemy.orm.scoped_session(db.sessionmaker)
try:
yield db.session
finally:
db.session.remove()
for table in reversed(db.Base.metadata.sorted_tables):
db.session.execute(table.delete())
db.session.commit()
2016-04-15 12:36:00 +00:00
2016-04-15 12:36:00 +00:00
@pytest.fixture
def context_factory(session):
def factory(params=None, files=None, user=None):
ctx = rest.Context(
method=None,
url=None,
headers={},
params=params or {},
files=files or {})
ctx.session = session
ctx.user = user or db.User()
return ctx
2016-04-15 12:36:00 +00:00
return factory
2016-04-15 12:36:00 +00:00
@pytest.fixture
def config_injector():
def injector(new_config_content):
config.config = new_config_content
return injector
2016-04-15 12:36:00 +00:00
@pytest.fixture
def user_factory():
2016-05-08 14:59:25 +00:00
def factory(name=None, rank=db.User.RANK_REGULAR, email='dummy'):
2016-04-15 12:36:00 +00:00
user = db.User()
user.name = name or get_unique_name()
2016-04-15 12:36:00 +00:00
user.password_salt = 'dummy'
user.password_hash = 'dummy'
user.email = email
2016-04-15 12:36:00 +00:00
user.rank = rank
user.creation_time = datetime(1997, 1, 1)
2016-04-15 12:36:00 +00:00
user.avatar_style = db.User.AVATAR_GRAVATAR
return user
return factory
2016-04-15 18:40:12 +00:00
@pytest.fixture
2016-04-24 07:50:11 +00:00
def tag_category_factory():
def factory(name=None, color='dummy', default=False):
category = db.TagCategory()
category.name = name or get_unique_name()
category.color = color
category.default = default
return category
return factory
2016-04-15 18:40:12 +00:00
@pytest.fixture
2016-04-24 07:50:11 +00:00
def tag_factory():
def factory(names=None, category=None):
if not category:
category = db.TagCategory(get_unique_name())
2016-04-24 07:50:11 +00:00
db.session.add(category)
2016-04-15 18:40:12 +00:00
tag = db.Tag()
tag.names = [
db.TagName(name) for name in names or [get_unique_name()]]
2016-04-15 18:40:12 +00:00
tag.category = category
tag.creation_time = datetime(1996, 1, 1)
2016-04-15 18:40:12 +00:00
return tag
return factory
2016-04-17 10:55:07 +00:00
2016-04-17 10:55:07 +00:00
@pytest.fixture
def post_factory():
# pylint: disable=invalid-name
2016-04-17 10:55:07 +00:00
def factory(
2016-04-22 18:58:04 +00:00
id=None,
2016-04-17 10:55:07 +00:00
safety=db.Post.SAFETY_SAFE,
type=db.Post.TYPE_IMAGE,
checksum='...'):
post = db.Post()
2016-04-22 18:58:04 +00:00
post.post_id = id
2016-04-17 10:55:07 +00:00
post.safety = safety
post.type = type
post.checksum = checksum
2016-04-22 18:58:04 +00:00
post.flags = []
2016-04-30 21:17:08 +00:00
post.mime_type = 'application/octet-stream'
post.creation_time = datetime(1996, 1, 1)
2016-04-17 10:55:07 +00:00
return post
return factory
2016-04-24 07:04:53 +00:00
2016-04-24 07:04:53 +00:00
@pytest.fixture
2016-04-24 07:50:11 +00:00
def comment_factory(user_factory, post_factory):
def factory(user=None, post=None, text='dummy', time=None):
2016-04-24 07:50:11 +00:00
if not user:
user = user_factory()
db.session.add(user)
if not post:
post = post_factory()
db.session.add(post)
2016-04-24 07:04:53 +00:00
comment = db.Comment()
2016-04-24 07:50:11 +00:00
comment.user = user
comment.post = post
2016-04-24 07:04:53 +00:00
comment.text = text
comment.creation_time = time or datetime(1996, 1, 1)
2016-04-24 07:04:53 +00:00
return comment
return factory
2016-04-30 21:17:08 +00:00
2016-04-30 21:17:08 +00:00
@pytest.fixture
def read_asset():
def get(path):
path = os.path.join(os.path.dirname(__file__), 'assets', path)
with open(path, 'rb') as handle:
return handle.read()
return get