From e378bf1da19ee2d260a88310c695bbe820a3e36c Mon Sep 17 00:00:00 2001 From: pi3c Date: Tue, 30 Jan 2024 13:05:15 +0300 Subject: [PATCH] =?UTF-8?q?typehint=20=D0=B2=20app=20=D0=B8=20conftest?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- fastfood/app.py | 2 +- tests/conftest.py | 25 ++++++++++++------------- 2 files changed, 13 insertions(+), 14 deletions(-) diff --git a/fastfood/app.py b/fastfood/app.py index d6c8852..0bed41c 100644 --- a/fastfood/app.py +++ b/fastfood/app.py @@ -61,7 +61,7 @@ tags_metadata = [ ] -def create_app(): +def create_app() -> FastAPI: """ Фабрика FastAPI. """ diff --git a/tests/conftest.py b/tests/conftest.py index 2d14188..c867b4c 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -1,20 +1,18 @@ import asyncio -from typing import AsyncGenerator -from httpx import AsyncClient +from typing import AsyncGenerator, Generator + import pytest import pytest_asyncio -from sqlalchemy.ext.asyncio import ( - AsyncSession, - async_sessionmaker, - create_async_engine, -) -from fastfood.app import create_app +from fastapi import FastAPI +from httpx import AsyncClient +from sqlalchemy.ext.asyncio import (AsyncSession, async_sessionmaker, + create_async_engine) +from fastfood.app import create_app from fastfood.config import settings from fastfood.dbase import get_async_session from fastfood.models import Base - async_engine = create_async_engine(settings.TESTDATABASE_URL_asyncpg) async_session_maker = async_sessionmaker( async_engine, @@ -49,16 +47,17 @@ async def get_test_session() -> AsyncGenerator[AsyncSession, None]: @pytest.fixture(scope="session") -def app(): - app = create_app() +def app() -> Generator[FastAPI, None, None]: + app: FastAPI = create_app() app.dependency_overrides[get_async_session] = get_test_session yield app @pytest_asyncio.fixture(scope="function") -async def client(app): +async def client(app) -> AsyncGenerator[AsyncClient, None]: async with AsyncClient( - app=app, base_url="http://localhost:8000/api/v1/menus", + app=app, + base_url="http://localhost:8000/api/v1/menus", ) as async_client: yield async_client