test: stabilize full test collection
This commit is contained in:
@@ -1,5 +1,6 @@
|
||||
"""Regression tests for task-result delivery into chat sessions (issue #326)."""
|
||||
import asyncio
|
||||
import sys
|
||||
import types as _types
|
||||
|
||||
import pytest
|
||||
@@ -11,6 +12,22 @@ if not isinstance(sqlalchemy, _types.ModuleType):
|
||||
from sqlalchemy import create_engine
|
||||
from sqlalchemy.orm import sessionmaker
|
||||
|
||||
|
||||
def _drop_fake_core_database():
|
||||
parent = sys.modules.get("core")
|
||||
attr = getattr(parent, "database", None) if parent is not None else None
|
||||
mod = sys.modules.get("core.database") or attr
|
||||
if mod is None or isinstance(getattr(mod, "__file__", None), str):
|
||||
return
|
||||
sys.modules.pop("core.database", None)
|
||||
sys.modules.pop("src.database", None)
|
||||
if parent is not None and attr is mod:
|
||||
delattr(parent, "database")
|
||||
|
||||
|
||||
_drop_fake_core_database()
|
||||
|
||||
import core.database as cdb
|
||||
from core.database import Base, Session as DbSession
|
||||
from src.task_scheduler import TaskScheduler
|
||||
|
||||
@@ -46,10 +63,15 @@ def _make_task():
|
||||
)
|
||||
|
||||
|
||||
def test_session_delivery_survives_empty_database():
|
||||
def test_session_delivery_survives_empty_database(monkeypatch):
|
||||
"""On a fresh/wiped database there is no session to inherit endpoint/model
|
||||
from, so _resolve_defaults returns None. The delivery must still persist a
|
||||
session instead of crashing on the NOT NULL constraint (issue #326)."""
|
||||
monkeypatch.setitem(sys.modules, "core.database", cdb)
|
||||
parent = sys.modules.get("core")
|
||||
if parent is not None:
|
||||
monkeypatch.setattr(parent, "database", cdb, raising=False)
|
||||
|
||||
db = _make_db()
|
||||
scheduler = TaskScheduler.__new__(TaskScheduler)
|
||||
scheduler._session_manager = None
|
||||
|
||||
Reference in New Issue
Block a user