This commit is contained in:
hajdul88 2025-10-17 10:18:39 +02:00
parent 16b073bf8c
commit 47cce90112

View file

@ -1,6 +1,5 @@
import pytest
from unittest.mock import AsyncMock, patch
from cognee.modules.users.methods import get_default_user
from unittest.mock import AsyncMock, patch, MagicMock
from cognee.context_global_variables import session_user
@ -17,13 +16,20 @@ def create_mock_cache_engine(qa_history=None):
return mock_cache
def create_mock_user():
"""Create a mock user without database access"""
mock_user = MagicMock()
mock_user.id = "test-user-id-123"
return mock_user
class TestConversationHistoryUtils:
"""Test the two utility functions: get_conversation_history and save_to_session_cache"""
@pytest.mark.asyncio
async def test_get_conversation_history_returns_empty_when_no_history(self):
"""Test get_conversation_history returns empty string when no history exists."""
user = await get_default_user()
user = create_mock_user()
session_user.set(user)
mock_cache = create_mock_cache_engine([])
@ -41,7 +47,7 @@ class TestConversationHistoryUtils:
@pytest.mark.asyncio
async def test_get_conversation_history_formats_history_correctly(self):
"""Test get_conversation_history formats Q&A history with correct structure."""
user = await get_default_user()
user = create_mock_user()
session_user.set(user)
mock_history = [
@ -71,7 +77,7 @@ class TestConversationHistoryUtils:
@pytest.mark.asyncio
async def test_save_to_session_cache_saves_correctly(self):
"""Test save_to_session_cache calls add_qa with correct parameters."""
user = await get_default_user()
user = create_mock_user()
session_user.set(user)
mock_cache = create_mock_cache_engine([])
@ -97,3 +103,28 @@ class TestConversationHistoryUtils:
assert call_kwargs["context"] == "Python is a programming language"
assert call_kwargs["answer"] == "Python is a high-level programming language"
assert call_kwargs["session_id"] == "my_session"
@pytest.mark.asyncio
async def test_save_to_session_cache_uses_default_session_when_none(self):
"""Test save_to_session_cache uses 'default_session' when session_id is None."""
user = create_mock_user()
session_user.set(user)
mock_cache = create_mock_cache_engine([])
with patch(
"cognee.infrastructure.databases.cache.get_cache_engine.get_cache_engine",
return_value=mock_cache,
):
from cognee.modules.retrieval.utils.session_cache import save_to_session_cache
result = await save_to_session_cache(
query="Test question",
context_summary="Test context",
answer="Test answer",
session_id=None,
)
assert result is True
call_kwargs = mock_cache.add_qa.call_args.kwargs
assert call_kwargs["session_id"] == "default_session"