gabriel / muse public

test_apply_archive_envelope.py file-level

at sha256:8 · View file ↗ · Intel ↗

History
1 files
1 commits
0 hotspots
0 🧊 dead
0 💥 blast risk
sha256:4 Merge branch 'dev' into main · gabriel · Jun 17, 2026
1 """Envelope tests for apply, apply_patch, archive."""
2 from __future__ import annotations
3 from collections.abc import Mapping
4 import json, pathlib
5 import pytest
6 from tests.cli_test_helper import CliRunner
7 runner = CliRunner()
8
9 _FIELDS = ("muse_version", "schema", "timestamp", "warnings")
10
11 def _has_envelope(d: Mapping[str, object]) -> None:
12 for f in _FIELDS:
13 assert f in d, f"missing {f}"
14 assert "schema_version" not in d
15
16 class TestApplyEnvelope:
17 def test_apply_json(self, tmp_path: pathlib.Path) -> None:
18 fake = tmp_path / "fake.patch"
19 fake.write_text("# fake patch\n")
20 r = runner.invoke(None, ["apply", str(fake), "--json"])
21 # may fail with user error but must emit JSON
22 try:
23 d = json.loads(r.output)
24 _has_envelope(d)
25 except (json.JSONDecodeError, AssertionError):
26 pytest.skip("apply errored before JSON output")
27
28 class TestApplyPatchEnvelope:
29 def test_check_has_envelope(self) -> None:
30 r = runner.invoke(None, ["apply-patch", "nonexistent.patch", "--check", "--json"])
31 try:
32 d = json.loads(r.output)
33 _has_envelope(d)
34 except (json.JSONDecodeError, AssertionError):
35 pytest.skip("apply-patch errored before JSON output")
36
37 class TestArchiveEnvelope:
38 def test_list_has_envelope(self) -> None:
39 r = runner.invoke(None, ["archive", "--list", "--json"])
40 assert r.exit_code == 0, r.output
41 d = json.loads(r.output)
42 _has_envelope(d)