gabriel / musehub public
clone_staging.py python
92 lines 2.5 KB
Raw
sha256:5601f81903b6c70ddd11bd88a5a257ee6dfd38aa3b85b19746c100c030657f1e chore: update smoke_muse.sh comment to reference rc9 Sonnet 4.6 minor ⚠ breaking 20 days ago
1 """Clone verb atomic tests against staging.musehub.ai.
2
3 Tests:
4 CL0: clone gabriel/timing-test (~100c+)
5 CL1: clone gabriel/muse (~799c)
6
7 Usage:
8 python3 scripts/clone_staging.py
9 """
10 from __future__ import annotations
11
12 import json
13 import os
14 import shutil
15 import subprocess
16 import sys
17 import time
18
19 MUSE = "muse"
20 HUB = "https://staging.musehub.ai"
21 OWNER = "gabriel"
22
23
24 def run(cmd: list[str], cwd: str | None = None, check: bool = True) -> subprocess.CompletedProcess:
25 return subprocess.run(cmd, cwd=cwd, capture_output=True, text=True, check=check)
26
27
28 def timed_clone_url(url: str, dest: str, branch: str = "main") -> dict:
29 if os.path.exists(dest):
30 shutil.rmtree(dest)
31 t0 = time.perf_counter()
32 r = run([MUSE, "clone", url, dest, "--branch", branch], check=False)
33 elapsed = round((time.perf_counter() - t0) * 1000, 1)
34 ok = r.returncode == 0
35 err = None
36 if not ok:
37 output = r.stdout + r.stderr
38 for line in output.splitlines():
39 if "❌" in line or "Error" in line or "failed" in line.lower():
40 err = line.strip()
41 break
42 if not err:
43 err = (r.stdout + r.stderr).strip()[:200]
44 commits_received = None
45 try:
46 d = json.loads(r.stdout)
47 commits_received = d.get("commits_received")
48 except Exception:
49 pass
50 return {"ok": ok, "t_total": elapsed, "error": err, "commits_received": commits_received}
51
52
53 def fmt(label: str, r: dict, extra: str = "") -> str:
54 ok = "✅" if r["ok"] else "❌"
55 err = f" ERROR: {r['error']}" if r.get("error") else ""
56 cr = r.get("commits_received")
57 received = f" [{cr}c received]" if cr is not None else ""
58 return (
59 f" {label:46s}"
60 f" total={str(r['t_total']):>9}ms"
61 f" {ok}{received}{extra}{err}"
62 )
63
64
65 CASES = [
66 ("CL0", "M", "timing-test", "~100c+"),
67 ("CL1", "L", "muse", "~799c"),
68 ]
69
70
71 def main() -> None:
72 print(f"\n── Clone atomic tests → {HUB} ──")
73 print(f" {'label':46s} {'total':>12} status")
74 print(" " + "-" * 90)
75
76 for tag, scale, repo_slug, size_label in CASES:
77 label = f"{tag}: clone {repo_slug} {size_label} ({scale})"
78 clone_url = f"{HUB}/{OWNER}/{repo_slug}"
79 dest = f"/tmp/clone-staging-{tag.lower()}"
80 r = timed_clone_url(clone_url, dest)
81 print(fmt(label, r))
82 sys.stdout.flush()
83
84 if not r["ok"]:
85 print(f"\n❌ {tag} failed — stopping.\n {r['error']}")
86 return
87
88 print()
89
90
91 if __name__ == "__main__":
92 main()
File History 2 commits
sha256:5601f81903b6c70ddd11bd88a5a257ee6dfd38aa3b85b19746c100c030657f1e chore: update smoke_muse.sh comment to reference rc9 Sonnet 4.6 minor 20 days ago
sha256:39e9c4e6f2134da0732e6983268a218178973936f8d7ca03c91f2b5ad42133c8 fix: use read_object_bytes in blob viewer; add zstd magic d… Sonnet 4.6 patch 20 days ago