test_coord_sync_envelope.py
file-level
1
files
1
commits
0
hotspots
0
🧊 dead
0
💥 blast risk
| 1 | """Envelope tests for coord sync command.""" |
| 2 | from __future__ import annotations |
| 3 | from collections.abc import Mapping |
| 4 | import json |
| 5 | import pytest |
| 6 | from tests.cli_test_helper import CliRunner |
| 7 | |
| 8 | runner = CliRunner() |
| 9 | |
| 10 | _FIELDS = ("muse_version", "schema", "timestamp", "warnings") |
| 11 | |
| 12 | |
| 13 | def _check(d: Mapping[str, object]) -> None: |
| 14 | for f in _FIELDS: |
| 15 | assert f in d, f"missing {f}" |
| 16 | assert "schema_version" not in d |
| 17 | |
| 18 | |
| 19 | class TestCoordSyncEnvelope: |
| 20 | def test_coord_sync_push_has_envelope(self) -> None: |
| 21 | # Push with no remote configured — will fail at hub resolution, |
| 22 | # but the no-records path (empty local state) exits before that. |
| 23 | r = runner.invoke(None, ["coord", "sync", "push", "--owner", "gabriel", "--slug", "muse", "--hub", "https://localhost:1337", "--json"]) |
| 24 | # exit_code may be non-zero if hub is unreachable, but the JSON |
| 25 | # must still carry the envelope when records were gathered first. |
| 26 | # Use the simpler no-records path: if no coordination records exist |
| 27 | # the command exits 0 with an envelope. |
| 28 | # We accept either 0 (no records) or non-zero (hub error). |
| 29 | output = r.output.strip() |
| 30 | if output.startswith("{"): |
| 31 | _check(json.loads(output)) |