0d898e09f2
run_all_migrations() now adopts/initializes only the app DB and returns
{'app': ...}. app/main.py drops the location/poo readiness checks
(ensure_location_db_ready / ensure_poo_db_ready) and their imports;
ensure_runtime_dirs only provisions the app DB path; lifespan still
fail-closes on a missing/unmanaged app DB. Delete the retired
location/poo adopt scripts and the alembic_location / alembic_poo
chains. Update tests to single-DB expectations and drop the obsolete
location/poo adoption + readiness tests.
pytest 95 passed; ruff clean (pre-existing only); a fresh app DB
initialized via scripts.run_migrations contains location + poo_records.
91 lines
2.7 KiB
Python
91 lines
2.7 KiB
Python
from pathlib import Path
|
|
|
|
import pytest
|
|
from alembic import command
|
|
from alembic.config import Config
|
|
from fastapi.testclient import TestClient
|
|
from sqlalchemy import create_engine
|
|
|
|
from app.db import reset_db_caches
|
|
from app.config import get_settings
|
|
from app.main import create_app
|
|
|
|
|
|
def _make_app_alembic_config(database_url: str) -> Config:
|
|
config = Config("alembic_app.ini")
|
|
config.set_main_option("sqlalchemy.url", database_url)
|
|
return config
|
|
|
|
|
|
@pytest.fixture
|
|
def test_database_urls(tmp_path: Path, monkeypatch: pytest.MonkeyPatch):
|
|
app_database_path = tmp_path / "app_test.db"
|
|
location_database_path = tmp_path / "location_test.db"
|
|
poo_database_path = tmp_path / "poo_placeholder.db"
|
|
app_database_url = f"sqlite:///{app_database_path}"
|
|
location_database_url = f"sqlite:///{location_database_path}"
|
|
poo_database_url = f"sqlite:///{poo_database_path}"
|
|
|
|
monkeypatch.setenv("APP_DATABASE_URL", app_database_url)
|
|
monkeypatch.setenv("LOCATION_DATABASE_URL", location_database_url)
|
|
monkeypatch.setenv("POO_DATABASE_URL", poo_database_url)
|
|
monkeypatch.setenv("AUTH_BOOTSTRAP_USERNAME", "admin")
|
|
monkeypatch.setenv("AUTH_BOOTSTRAP_PASSWORD", "test-password")
|
|
monkeypatch.setenv("AUTH_COOKIE_SECURE_OVERRIDE", "false")
|
|
get_settings.cache_clear()
|
|
reset_db_caches()
|
|
|
|
try:
|
|
yield {
|
|
"app_path": app_database_path,
|
|
"app_url": app_database_url,
|
|
"location_path": location_database_path,
|
|
"location_url": location_database_url,
|
|
"poo_path": poo_database_path,
|
|
"poo_url": poo_database_url,
|
|
}
|
|
finally:
|
|
get_settings.cache_clear()
|
|
reset_db_caches()
|
|
|
|
|
|
@pytest.fixture
|
|
def auth_database(test_database_urls, monkeypatch: pytest.MonkeyPatch):
|
|
database_url = test_database_urls["app_url"]
|
|
command.upgrade(_make_app_alembic_config(database_url), "head")
|
|
reset_db_caches()
|
|
|
|
yield test_database_urls
|
|
reset_db_caches()
|
|
|
|
|
|
@pytest.fixture
|
|
def app(auth_database):
|
|
yield create_app()
|
|
|
|
|
|
@pytest.fixture
|
|
def client(app):
|
|
with TestClient(app) as test_client:
|
|
yield test_client
|
|
|
|
|
|
@pytest.fixture
|
|
def location_client(auth_database):
|
|
app_url = auth_database["app_url"]
|
|
engine = create_engine(app_url, connect_args={"check_same_thread": False})
|
|
fastapi_app = create_app()
|
|
with TestClient(fastapi_app) as client:
|
|
yield client, engine
|
|
engine.dispose()
|
|
|
|
|
|
@pytest.fixture
|
|
def poo_client(auth_database):
|
|
app_url = auth_database["app_url"]
|
|
engine = create_engine(app_url, connect_args={"check_same_thread": False})
|
|
fastapi_app = create_app()
|
|
with TestClient(fastapi_app) as client:
|
|
yield client, engine
|
|
engine.dispose()
|