|
|
|
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://apistar:local@localhost/{{cookiecutter.project_slug}}',
|
|
|
|
'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)
|