refactor: split table models into Base/Table/Public for proper FastAPI serialization

Add ProductBase, ProductPublic, ProductWithInventory and
SkinConditionSnapshotBase, SkinConditionSnapshotPublic. Table models now inherit
from their Base counterpart and override JSON fields with sa_column. All
field_serializer hacks removed; FastAPI response models use the non-table Public
classes so Pydantic coerces raw DB dicts → typed models cleanly. ProductCreate
and SnapshotCreate now simply inherit their respective Base classes.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
Piotr Oleszczyk 2026-02-27 15:37:46 +01:00
parent 479be25112
commit c09acc7c81
15 changed files with 225 additions and 198 deletions

View file

@ -112,9 +112,7 @@ def test_update_snapshot_concerns(client):
def test_update_snapshot_not_found(client):
r = client.patch(
f"/skincare/{uuid.uuid4()}", json={"overall_state": "good"}
)
r = client.patch(f"/skincare/{uuid.uuid4()}", json={"overall_state": "good"})
assert r.status_code == 404