mirror of
https://gitlab.com/MoonTestUse1/AdministrationItDepartmens.git
synced 2025-08-14 00:25:46 +02:00
Fix database
This commit is contained in:
@@ -11,6 +11,8 @@ pytest>=7.4.0
|
||||
pytest-cov>=4.1.0
|
||||
pytest-timeout>=2.1.0
|
||||
pytest-xdist>=3.3.1
|
||||
pytest-mock>=3.10.0
|
||||
httpx>=0.24.1
|
||||
redis>=4.6.0
|
||||
aiogram>=3.4.0
|
||||
python-telegram-bot>=20.4
|
||||
|
@@ -1,68 +1,94 @@
|
||||
"""Test configuration"""
|
||||
import os
|
||||
import pytest
|
||||
from sqlalchemy import create_engine, text
|
||||
from sqlalchemy.orm import sessionmaker, scoped_session
|
||||
from fastapi.testclient import TestClient
|
||||
from typing import Generator, Any
|
||||
from sqlalchemy import create_engine
|
||||
from sqlalchemy.orm import sessionmaker
|
||||
from sqlalchemy.pool import StaticPool
|
||||
|
||||
# Устанавливаем переменную окружения для тестов
|
||||
os.environ["TESTING"] = "1"
|
||||
|
||||
from app.database import Base
|
||||
from app.core.config import settings
|
||||
from app.db.base import Base
|
||||
from app.main import app
|
||||
from app.core.test_config import test_settings
|
||||
from app.dependencies import get_db
|
||||
from .test_fixtures import * # импортируем все фикстуры
|
||||
from app.deps import get_db
|
||||
from app.models.employee import Employee
|
||||
from app.utils.security import get_password_hash
|
||||
|
||||
# Создаем тестовый движок базы данных
|
||||
DATABASE_URL = os.getenv("DATABASE_URL", test_settings.get_database_url())
|
||||
# Mock Telegram notifications
|
||||
@pytest.fixture(autouse=True)
|
||||
def mock_telegram_bot(mocker):
|
||||
"""Mock Telegram Bot"""
|
||||
mock_bot = mocker.patch('app.utils.telegram.Bot')
|
||||
return mock_bot
|
||||
|
||||
@pytest.fixture(autouse=True)
|
||||
def mock_telegram_notify(mocker):
|
||||
"""Mock Telegram notifications"""
|
||||
mocker.patch('app.utils.telegram.notify_new_request', return_value=None)
|
||||
|
||||
# Database fixtures
|
||||
@pytest.fixture(scope="session")
|
||||
def engine():
|
||||
"""Create test database engine"""
|
||||
engine = create_engine(
|
||||
DATABASE_URL,
|
||||
pool_size=5,
|
||||
max_overflow=10,
|
||||
pool_timeout=30,
|
||||
pool_pre_ping=True
|
||||
"sqlite:///:memory:",
|
||||
connect_args={"check_same_thread": False},
|
||||
poolclass=StaticPool,
|
||||
)
|
||||
|
||||
# Создаем тестовую фабрику сессий
|
||||
TestingSessionLocal = scoped_session(
|
||||
sessionmaker(autocommit=False, autoflush=False, bind=engine)
|
||||
)
|
||||
|
||||
@pytest.fixture(scope="session", autouse=True)
|
||||
def setup_test_db() -> Generator[None, Any, None]:
|
||||
"""Setup test database"""
|
||||
# Создаем все таблицы
|
||||
Base.metadata.drop_all(bind=engine)
|
||||
Base.metadata.create_all(bind=engine)
|
||||
yield
|
||||
# Удаляем все таблицы и закрываем соединения
|
||||
TestingSessionLocal.remove()
|
||||
Base.metadata.drop_all(bind=engine)
|
||||
engine.dispose()
|
||||
return engine
|
||||
|
||||
@pytest.fixture(scope="function")
|
||||
def db_session() -> Generator[Any, Any, None]:
|
||||
"""Get database session"""
|
||||
session = TestingSessionLocal()
|
||||
def db_session(engine):
|
||||
"""Create test database session"""
|
||||
Session = sessionmaker(bind=engine)
|
||||
session = Session()
|
||||
try:
|
||||
yield session
|
||||
finally:
|
||||
session.rollback()
|
||||
session.close()
|
||||
TestingSessionLocal.remove()
|
||||
|
||||
@pytest.fixture(scope="function")
|
||||
def client(db_session: Any) -> Generator[TestClient, Any, None]:
|
||||
"""Get test client"""
|
||||
def override_get_db() -> Generator[Any, Any, None]:
|
||||
@pytest.fixture
|
||||
def client(db_session):
|
||||
"""Create test client"""
|
||||
def override_get_db():
|
||||
try:
|
||||
yield db_session
|
||||
finally:
|
||||
pass
|
||||
|
||||
app.dependency_overrides[get_db] = override_get_db
|
||||
with TestClient(app) as test_client:
|
||||
yield test_client
|
||||
app.dependency_overrides.clear()
|
||||
return TestClient(app)
|
||||
|
||||
@pytest.fixture
|
||||
def test_employee(db_session):
|
||||
"""Create test employee"""
|
||||
employee = Employee(
|
||||
first_name="Test",
|
||||
last_name="User",
|
||||
department="IT",
|
||||
office="Main",
|
||||
hashed_password=get_password_hash("testpass123"),
|
||||
is_active=True,
|
||||
is_admin=False
|
||||
)
|
||||
db_session.add(employee)
|
||||
db_session.commit()
|
||||
db_session.refresh(employee)
|
||||
return employee
|
||||
|
||||
@pytest.fixture
|
||||
def test_admin(db_session):
|
||||
"""Create test admin"""
|
||||
admin = Employee(
|
||||
first_name="Admin",
|
||||
last_name="User",
|
||||
department="IT",
|
||||
office="Main",
|
||||
hashed_password=get_password_hash("adminpass123"),
|
||||
is_active=True,
|
||||
is_admin=True
|
||||
)
|
||||
db_session.add(admin)
|
||||
db_session.commit()
|
||||
db_session.refresh(admin)
|
||||
return admin
|
Reference in New Issue
Block a user