clone_staging.py
python
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