You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

52 lines
1.3 KiB
Python

from apistar.frameworks.wsgi import WSGIApp
from apistar.backends.sqlalchemy_backend import SQLAlchemyBackend, get_session
import pytest
from {{cookiecutter.project_slug}}.models import Base
from {{cookiecutter.project_slug}}.renders import JSONRenderer
from {{cookiecutter.project_slug}}.app import commands, routes, components
settings = {
'DATABASE': {
#'URL': 'postgresql://@localhost/test_{{cookiecutter.project_name}}',
'URL': 'sqlite:///',
'METADATA': Base.metadata
},
'RENDERERS': [JSONRenderer()],
}
backend = SQLAlchemyBackend(settings)
@pytest.fixture(autouse=True)
def create_db():
"""Creates a test database with session scope"""
Base.metadata.create_all(backend.engine)
yield
Base.metadata.drop_all(backend.engine)
@pytest.fixture(name='rb_session')
def db_session_fixure():
"""Returns a SQLAlchemy session with automatic rollback"""
session = backend.Session()
try:
yield session
session.rollback()
except:
session.rollback()
raise
finally:
session.close()
@pytest.fixture(name='app', scope='session')
def apistar_app_fixture():
"""Returns a session scoped WSGIApp instance"""
return WSGIApp(settings=settings,
commands=commands,
components=components,
routes=routes)