mirror of
https://github.com/Kludex/awesome-fastapi-projects.git
synced 2024-12-18 08:10:18 +00:00
106 lines
3.3 KiB
Python
106 lines
3.3 KiB
Python
|
"""The application-level conftest."""
|
||
|
import asyncio
|
||
|
import contextlib
|
||
|
from collections.abc import AsyncGenerator, Generator
|
||
|
from typing import Literal
|
||
|
|
||
|
import pytest
|
||
|
import stamina
|
||
|
from dirty_equals import IsList
|
||
|
from pytest_mock import MockerFixture
|
||
|
from sqlalchemy.ext.asyncio import AsyncConnection, AsyncSession
|
||
|
|
||
|
from app.database import Dependency, Repo
|
||
|
from app.factories import DependencyCreateDataFactory
|
||
|
from app.source_graph.factories import SourceGraphRepoDataFactory
|
||
|
from app.source_graph.models import SourceGraphRepoData
|
||
|
|
||
|
|
||
|
@pytest.fixture(autouse=True, scope="session")
|
||
|
def anyio_backend() -> Literal["asyncio"]:
|
||
|
"""Use asyncio as the async backend."""
|
||
|
return "asyncio"
|
||
|
|
||
|
|
||
|
@pytest.fixture(autouse=True, scope="session")
|
||
|
def _deactivate_retries() -> None:
|
||
|
"""Deactivate stamina retries."""
|
||
|
stamina.set_active(False)
|
||
|
|
||
|
|
||
|
@pytest.fixture(autouse=True)
|
||
|
def _test_db(mocker: MockerFixture) -> None:
|
||
|
"""Use the in-memory database for tests."""
|
||
|
mocker.patch("app.database.DB_PATH", "")
|
||
|
|
||
|
|
||
|
@pytest.fixture(scope="session")
|
||
|
def event_loop(
|
||
|
request: pytest.FixtureRequest,
|
||
|
) -> Generator[asyncio.AbstractEventLoop, None, None]:
|
||
|
"""
|
||
|
Create an instance of the default event loop for a session.
|
||
|
|
||
|
An event loop is destroyed at the end of the test session.
|
||
|
https://docs.pytest.org/en/6.2.x/fixture.html#fixture-scopes
|
||
|
"""
|
||
|
with contextlib.closing(loop := asyncio.get_event_loop_policy().get_event_loop()):
|
||
|
yield loop
|
||
|
|
||
|
|
||
|
@pytest.fixture(scope="session")
|
||
|
async def test_db_connection() -> AsyncGenerator[AsyncConnection, None]:
|
||
|
"""Use the in-memory database for tests."""
|
||
|
from app.database import Base, engine
|
||
|
|
||
|
try:
|
||
|
async with engine.begin() as conn:
|
||
|
await conn.run_sync(Base.metadata.drop_all)
|
||
|
await conn.run_sync(Base.metadata.create_all)
|
||
|
yield conn
|
||
|
finally:
|
||
|
# for AsyncEngine created in function scope, close and
|
||
|
# clean-up pooled connections
|
||
|
await engine.dispose()
|
||
|
|
||
|
|
||
|
@pytest.fixture()
|
||
|
async def test_db_session(
|
||
|
test_db_connection: AsyncConnection,
|
||
|
) -> AsyncGenerator[AsyncSession, None]:
|
||
|
"""Use the in-memory database for tests."""
|
||
|
from app.uow import async_session_uow
|
||
|
|
||
|
async with async_session_uow() as session:
|
||
|
yield session
|
||
|
|
||
|
|
||
|
@pytest.fixture()
|
||
|
async def some_repos(
|
||
|
test_db_session: AsyncSession,
|
||
|
source_graph_repo_data_factory: SourceGraphRepoDataFactory,
|
||
|
dependency_create_data_factory: DependencyCreateDataFactory,
|
||
|
) -> list[Repo]:
|
||
|
"""Create some repos."""
|
||
|
source_graph_repos_data: list[
|
||
|
SourceGraphRepoData
|
||
|
] = source_graph_repo_data_factory.batch(10)
|
||
|
assert source_graph_repos_data == IsList(length=10)
|
||
|
repos = [
|
||
|
Repo(
|
||
|
url=str(source_graph_repo_data.repo_url),
|
||
|
description=source_graph_repo_data.description,
|
||
|
stars=source_graph_repo_data.stars,
|
||
|
source_graph_repo_id=source_graph_repo_data.repo_id,
|
||
|
dependencies=[
|
||
|
Dependency(**dependency_create_data.model_dump())
|
||
|
for dependency_create_data in dependency_create_data_factory.batch(5)
|
||
|
],
|
||
|
)
|
||
|
for source_graph_repo_data in source_graph_repos_data
|
||
|
]
|
||
|
test_db_session.add_all(repos)
|
||
|
await test_db_session.flush()
|
||
|
await asyncio.gather(*[test_db_session.refresh(repo) for repo in repos])
|
||
|
return repos
|