2023-08-15 13:17:14 +02:00

78 lines
2.6 KiB
Python

"""Test the operations on the database models."""
import pytest
import sqlalchemy as sa
import sqlalchemy.orm
from dirty_equals import IsList
from sqlalchemy.ext.asyncio import AsyncSession
from app import database
from app.factories import RepoCreateDataFactory
pytestmark = pytest.mark.anyio
async def test_create_repo_no_dependencies(
test_db_session: AsyncSession, repo_create_data_factory: RepoCreateDataFactory
) -> None:
"""Test creating a repo."""
repo_create_data = repo_create_data_factory.build()
repo = database.Repo(url=str(repo_create_data.url))
test_db_session.add(repo)
await test_db_session.flush()
await test_db_session.refresh(repo)
assert repo.id is not None
assert repo.url == str(repo_create_data.url)
assert (await repo.awaitable_attrs.dependencies) == IsList(length=0)
async def test_create_repo_with_dependencies(
test_db_session: AsyncSession, repo_create_data_factory: RepoCreateDataFactory
) -> None:
"""Test creating a repo with dependencies."""
repo_create_data = repo_create_data_factory.build()
repo = database.Repo(
url=str(repo_create_data.url),
dependencies=[
database.Dependency(name=dependency.name)
for dependency in repo_create_data.dependencies
],
)
test_db_session.add(repo)
await test_db_session.flush()
await test_db_session.refresh(repo)
assert repo.id is not None
assert repo.url == str(repo_create_data.url)
repo_dependencies = await repo.awaitable_attrs.dependencies
assert 2 <= len(repo_dependencies) <= 5
assert repo_dependencies == IsList(length=len(repo_create_data.dependencies))
assert all(
repo_dependency.name == dependency.name
for repo_dependency, dependency in zip(
repo_dependencies, repo_create_data.dependencies, strict=True
)
)
async def test_list_repositories(
test_db_session: AsyncSession,
some_repos: list[database.Repo],
) -> None:
"""Test listing repositories."""
repos_from_db_result = await test_db_session.execute(
sa.select(database.Repo).options(
sqlalchemy.orm.joinedload(database.Repo.dependencies)
)
)
repos_from_db = repos_from_db_result.scalars().unique().all()
assert repos_from_db == IsList(length=10)
assert all(
repo.url == str(repo_create_data.url)
and all(
repo_dependency.name == dependency.name
for repo_dependency, dependency in zip(
repo.dependencies, repo_create_data.dependencies, strict=True
)
)
for repo, repo_create_data in zip(repos_from_db, some_repos, strict=True)
)