Wrap blocking mkdir() calls in run_blocking for async startup and setup
This commit is contained in:
@@ -54,6 +54,8 @@ Any user action that exercises an error path on the `/config/global`, `/config/r
|
||||
|
||||
### TASK-02 — Wrap blocking `mkdir()` calls in `run_blocking()` 🔴
|
||||
|
||||
**Status:** Completed ✅
|
||||
|
||||
**Where:**
|
||||
- `backend/app/services/setup_service.py` — line 178, inside `async def _ensure_database_initialized()`
|
||||
- `backend/app/startup.py` — line 73, inside `async def startup_shared_resources()`
|
||||
|
||||
@@ -175,7 +175,7 @@ async def _ensure_database_initialized(database_path: str) -> bool:
|
||||
parent_dir = database_path_obj.parent
|
||||
|
||||
try:
|
||||
parent_dir.mkdir(parents=True, exist_ok=True)
|
||||
await run_blocking(parent_dir.mkdir, parents=True, exist_ok=True)
|
||||
except PermissionError:
|
||||
log.warning(
|
||||
"cannot_create_runtime_database_parent",
|
||||
|
||||
@@ -70,7 +70,7 @@ async def startup_shared_resources(
|
||||
A tuple of ``(http_session, scheduler)``.
|
||||
"""
|
||||
db_path: Path = Path(settings.database_path)
|
||||
db_path.parent.mkdir(parents=True, exist_ok=True)
|
||||
await run_blocking(db_path.parent.mkdir, parents=True, exist_ok=True)
|
||||
|
||||
log.debug("database_directory_ensured", directory=str(db_path.parent))
|
||||
|
||||
|
||||
Reference in New Issue
Block a user