refactor: move business logic out of presentation — ReadAssetFile, checksum, auth checks, MetadataValue conversions

This commit is contained in:
2026-05-31 06:10:07 +02:00
parent 0f003a3bd6
commit 34b231a8f6
18 changed files with 256 additions and 43 deletions

View File

@@ -16,12 +16,13 @@ async fn returns_asset_with_resolved_metadata() {
relative_path: "photos/img.jpg".into(),
checksum: Checksum::new("a".repeat(64)).unwrap(),
};
let owner = SystemId::new();
let asset = Asset::new(
source,
AssetType::Image,
"image/jpeg",
1024,
SystemId::new(),
owner,
);
asset_repo.save(&asset).await.unwrap();
@@ -42,6 +43,7 @@ async fn returns_asset_with_resolved_metadata() {
let (returned, resolved) = handler
.execute(GetAssetQuery {
asset_id: asset.asset_id,
user_id: owner,
})
.await
.unwrap();
@@ -62,8 +64,35 @@ async fn rejects_nonexistent() {
let result = handler
.execute(GetAssetQuery {
asset_id: SystemId::new(),
user_id: SystemId::new(),
})
.await;
assert!(matches!(result, Err(DomainError::NotFound(_))));
}
#[tokio::test]
async fn rejects_forbidden_access() {
let asset_repo = Arc::new(InMemoryAssetRepository::new());
let meta_repo = Arc::new(InMemoryAssetMetadataRepository::new());
let source = SourceReference {
volume_id: SystemId::new(),
relative_path: "photos/img.jpg".into(),
checksum: Checksum::new("a".repeat(64)).unwrap(),
};
let owner = SystemId::new();
let asset = Asset::new(source, AssetType::Image, "image/jpeg", 1024, owner);
asset_repo.save(&asset).await.unwrap();
let handler = GetAssetHandler::new(asset_repo, meta_repo);
let other_user = SystemId::new();
let result = handler
.execute(GetAssetQuery {
asset_id: asset.asset_id,
user_id: other_user,
})
.await;
assert!(matches!(result, Err(DomainError::Forbidden(_))));
}