"""plausible — UPGRADE overlay (Phase 1e HC3): data-integrity, assertion-only. Reads the postgres ci_marker via psql in the `db` service (plausible's metadata DB; pg_dump backup hook).""" import os import sys sys.path.insert(0, os.path.join(os.path.dirname(__file__), "..", "..", "runner")) from harness import lifecycle # noqa: E402 def _psql(domain, sql): cmd = f'PGPASSWORD="$POSTGRES_PASSWORD" psql -U "$POSTGRES_USER" -d "$POSTGRES_DB" -tAc "{sql}"' return lifecycle.exec_in_app(domain, ["sh", "-c", cmd], service="db").strip() def test_upgrade_preserves_data(live_app): assert _psql(live_app, "SELECT v FROM ci_marker;") == "upgrade-survives", "postgres data did not survive the upgrade"