aibilly_backend_code/tests/unit/audit_log_service.test.py
2026-03-10 16:44:04 +05:30

104 lines
3.1 KiB
Python

"""
Unit Tests for AuditLogService
Generated test cases for service layer
"""
import pytest
from unittest.mock import Mock, patch
from src.services._service import AuditLogService
from src.errors.error import NotFoundError, ValidationError
@pytest.fixture
def service():
return AuditLogService()
@pytest.fixture
def mock_model():
return Mock()
class TestAuditLogService:
def test_create_success(self, service, mock_model):
"""Test successful creation of """
data = {
"id": True,
"user_id": True,
"entity_type": "testentity_type",
"entity_id": True,
"action": "testaction",
"action_category": "testaction_category",
"old_values": True,
"new_values": True,
"changes_summary": True,
"ip_address": "testip_address",
"user_agent": True,
"session_id": "testsession_id",
"request_id": "testrequest_id",
"status": "teststatus",
"error_message": True,
"metadata": True,
"phi_accessed": True,
"compliance_flag": True,
"": True,
}
created = {**data, "id": 1}
with patch('src.services._service.AuditLogModel') as mock:
mock.create.return_value = created
result = service.create(data)
assert result == created
mock.create.assert_called_once_with(data)
def test_create_validation_error(self, service):
"""Test validation error on invalid data"""
invalid_data = {}
with pytest.raises(ValidationError):
service.create(invalid_data)
def test_find_by_id_success(self, service, mock_model):
"""Test successful retrieval by id"""
id = 1
found = {"id": id, "name": "Test"}
with patch('src.services._service.AuditLogModel') as mock:
mock.get.return_value = found
result = service.find_by_id(id)
assert result == found
mock.get.assert_called_once_with(id)
def test_find_by_id_not_found(self, service):
"""Test NotFoundError when not found"""
id = 999
with patch('src.services._service.AuditLogModel') as mock:
mock.get.return_value = None
with pytest.raises(NotFoundError):
service.find_by_id(id)
def test_update_success(self, service):
"""Test successful update"""
id = 1
update_data = {"name": "Updated"}
updated = {"id": id, **update_data}
with patch('src.services._service.AuditLogModel') as mock:
mock.get.return_value = {"id": id}
mock.update.return_value = updated
result = service.update(id, update_data)
assert result == updated
def test_delete_success(self, service):
"""Test successful deletion"""
id = 1
with patch('src.services._service.AuditLogModel') as mock:
mock.get.return_value = {"id": id}
mock.delete.return_value = True
service.delete(id)
mock.delete.assert_called_once_with(id)