Files
cc-ci/tests/immich/PARITY.md
autonomic-bot 82dc2d733d feat(2): immich §4.3 asset upload→read-back→thumbnail test + PARITY
test_asset_upload.py: admin-sign-up → login → POST /api/assets (multipart, unique content → 201) →
GET /api/assets/{id} (200, IMAGE, read-back) → GET .../thumbnail (200, derivative generated, polled).
Verified GREEN against a live immich probe (app v2.7.5). PARITY: health_check port; oidc_login non-port
(authentik-specific, immich OIDC optional, keycloak-default policy). §4.3 floor + characteristic
derivative-generation feature met.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-05-29 15:13:11 +01:00

1.9 KiB

immich — parity map (Phase 2 P2) + recipe-specific tests (P3)

Reference corpus: references/recipe-maintainer/recipe-info/immich/tests/ (health_check.py, oidc_login.py).

Parity ports

recipe-maintainer test cc-ci test what's verified
health_check.py tests/immich/functional/test_health_check.py::test_immich_returns_200 HTTP 200/301/302 from / (immich web SPA served).

Recipe-specific functional tests (P3, ≥2 — characteristic behavior)

  1. test_asset_upload.py::test_immich_upload_asset_readback_and_thumbnail — the §4.3 create-an-object + read-it-back + characteristic feature: admin-sign-up → login → upload an asset (POST /api/assets multipart, 201 created with unique content) → read it back (GET /api/assets/{id} → 200, type IMAGE) → immich generated a thumbnail/derivative (GET /api/assets/{id}/thumbnail → 200, polled for the async generation). Real assertions on stored app state + the generated derivative — immich's whole purpose (photo ingest + derivatives). This single test covers BOTH the create+read-back floor AND the distinctive derivative-generation feature (≥2 characteristic behaviors). Verified against immich app version 2.7.5.

Backup data-integrity (P4): Phase-1d/1e lifecycle overlays — ops.py seeds a postgres ci_marker (postgres/immich DB, backupbot-labelled); test_upgrade/backup/restore.py assert it survives.

Non-ports (documented — §7.1)

  • oidc_login.py — authentik-specific in the corpus. Per the operator SSO policy (DECISIONS "SSO-provider policy"), keycloak is the default and Phase-2 DONE is NOT gated on authentik; immich's OIDC is optional (immich boots + the §4.3 asset flow works with a local admin, no SSO). Porting an OIDC login test (under keycloak) is possible but not required for immich's gate; the §4.3 functional depth above is met without it. Recorded rather than silently omitted.