Coverage for arclith / application / use_cases / duplicate.py: 100%
15 statements
« prev ^ index » next coverage.py v7.13.5, created at 2026-03-25 15:02 +0100
« prev ^ index » next coverage.py v7.13.5, created at 2026-03-25 15:02 +0100
1from typing import Generic, TypeVar
2from uuid6 import UUID
4from arclith.domain.models.entity import Entity
5from arclith.domain.ports.logger import Logger
6from arclith.domain.ports.repository import Repository
8T = TypeVar("T", bound=Entity)
11class DuplicateUseCase(Generic[T]):
12 def __init__(self, repository: Repository[T], logger: Logger) -> None:
13 self._repository = repository
14 self._logger = logger
16 async def execute(self, uuid: UUID) -> T:
17 self._logger.info("📋 Duplicating entity", uuid=str(uuid))
18 result = await self._repository.duplicate(uuid)
19 self._logger.info("✅ Entity duplicated", original_uuid=str(uuid), new_uuid=str(result.uuid))
20 return result