feat(mosaic): mosaic update re-seeds framework + relaunches agents (R13) #610

Merged
jason.woltje merged 1 commits from feat/f3-m3-update-reseed into main 2026-06-22 03:34:06 +00:00
Owner

F3-m3 — mosaic update re-seeds framework + relaunches agents (closes R13)

The gap you found in 0.0.39 production validation: mosaic update installs the new npm CLI but never re-seeds ~/.config/mosaic/ from the package's bundled framework/. So the shipped custom Pi harness (agent-name export + native HB) stays dormant until a manual re-seed — operators (and w-jarvis) get the new CLI on a stale framework.

What this does

After a successful mosaic update install that includes @mosaicstack/mosaic:

  1. Re-seeds the framework from the freshly-installed package's install.sh in MOSAIC_SYNC_ONLY=1 MOSAIC_INSTALL_MODE=keep — the P4 data-safe reconcile (framework-owned overwrite + backup-once; SOUL/USER/*.local/credentials preserved). Default-on; --no-reseed opts out. This is the R13 fix — shipped launcher/runtime changes now activate.
  2. Relaunches durable agents--relaunch restarts rostered agents (systemctl --user restart mosaic-agent@<name>) so they pick up the new launcher/extension; default prints clear activation guidance (restarting running agents is disruptive, so it's opt-in).

Flow: update CLI → re-seed framework (data-safe) → relaunch agents (opt-in).

Implementation

  • update-checker.ts: resolveBundledFrameworkRoot, buildReseedCommand, runFrameworkReseed, readRosterAgentNames, buildRelaunchCommands (pure builders + a best-effort runner that reports rather than throws).
  • cli.ts update: --no-reseed / --relaunch flags + the post-install steps; only re-seeds when the framework-bearing package actually updated.

Verification

  • 6 new unit tests (reseed command/env, relaunch commands, roster parse, missing-installer guard) + 19 runtime + 26 launch tests green. tsc/eslint/prettier clean.
  • Sync data-safety already proven (P4 5-fixture matrix + the live dragon-lin validation, zero data loss).

Note

Best validated on a real host with a fleet (w-jarvis): mosaic update --relaunch → confirm start-agent-session.sh + mosaic-extension.ts in ~/.config/mosaic match the new package and agents come back on the native HB. The re-seed uses the local installed package (no network).

🤖 Generated with Claude Code

## F3-m3 — `mosaic update` re-seeds framework + relaunches agents (closes R13) **The gap you found in 0.0.39 production validation:** `mosaic update` installs the new npm CLI but never re-seeds `~/.config/mosaic/` from the package's bundled `framework/`. So the shipped custom Pi harness (agent-name export + native HB) stays **dormant** until a manual re-seed — operators (and w-jarvis) get the new CLI on a **stale framework**. ### What this does After a successful `mosaic update` install that includes `@mosaicstack/mosaic`: 1. **Re-seeds the framework** from the freshly-installed package's `install.sh` in `MOSAIC_SYNC_ONLY=1 MOSAIC_INSTALL_MODE=keep` — the **P4 data-safe reconcile** (framework-owned overwrite + backup-once; `SOUL`/`USER`/`*.local`/`credentials` preserved). Default-on; `--no-reseed` opts out. **This is the R13 fix** — shipped launcher/runtime changes now activate. 2. **Relaunches durable agents** — `--relaunch` restarts rostered agents (`systemctl --user restart mosaic-agent@<name>`) so they pick up the new launcher/extension; default prints clear activation guidance (restarting running agents is disruptive, so it's opt-in). Flow: `update CLI → re-seed framework (data-safe) → relaunch agents (opt-in)`. ### Implementation - `update-checker.ts`: `resolveBundledFrameworkRoot`, `buildReseedCommand`, `runFrameworkReseed`, `readRosterAgentNames`, `buildRelaunchCommands` (pure builders + a best-effort runner that reports rather than throws). - `cli.ts` `update`: `--no-reseed` / `--relaunch` flags + the post-install steps; only re-seeds when the framework-bearing package actually updated. ### Verification - **6 new unit tests** (reseed command/env, relaunch commands, roster parse, missing-installer guard) + **19 runtime + 26 launch** tests green. tsc/eslint/prettier clean. - Sync data-safety already proven (P4 5-fixture matrix + the live dragon-lin validation, zero data loss). ### Note Best validated on a real host with a fleet (w-jarvis): `mosaic update --relaunch` → confirm `start-agent-session.sh` + `mosaic-extension.ts` in `~/.config/mosaic` match the new package and agents come back on the native HB. The re-seed uses the local installed package (no network). 🤖 Generated with [Claude Code](https://claude.com/claude-code)
jason.woltje added 1 commit 2026-06-22 03:29:37 +00:00
feat(mosaic): mosaic update re-seeds framework + relaunches agents (#609)
All checks were successful
ci/woodpecker/push/ci Pipeline was successful
ci/woodpecker/pr/ci Pipeline was successful
dcb7477007
Closes R13 (F3-m3). mosaic update installed the new npm CLI but never
re-seeded ~/.config/mosaic from the package's bundled framework/, so shipped
launcher/runtime changes (agent-name export + native HB) stayed DORMANT until
a manual re-seed — operators got the new CLI on a stale framework.

- update-checker.ts: resolveBundledFrameworkRoot, buildReseedCommand (install.sh
  in MOSAIC_SYNC_ONLY=1 MOSAIC_INSTALL_MODE=keep — the P4 data-safe reconcile:
  framework-owned overwrite + backup-once; SOUL/USER/*.local/credentials kept),
  runFrameworkReseed, readRosterAgentNames, buildRelaunchCommands.
- cli.ts update: after a successful CLI install that includes @mosaicstack/mosaic,
  re-seed the framework (default-on; --no-reseed to skip). Then --relaunch restarts
  rostered agents (systemctl --user restart mosaic-agent@<name>), else prints clear
  activation guidance. Only re-seeds when the framework-bearing package updated.

Flow: update CLI -> re-seed framework (data-safe) -> relaunch agents (opt-in).

Verified: 6 new unit tests + 19 runtime + 26 launch tests green; tsc/eslint/
prettier clean. Sync data-safety already proven (P4 matrix + live validation).

Refs #609

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
Claude-Session: https://claude.ai/code/session_01EsgTQzV5YUGk1JtCLP4B83
jason.woltje merged commit 8ddd48c843 into main 2026-06-22 03:34:06 +00:00
Sign in to join this conversation.
No Reviewers
1 Participants
Notifications
Due Date
No due date set.
Dependencies

No dependencies set.

Reference: mosaicstack/stack#610