vm run: ship tracked files only by default; add --include-untracked + --dry-run
Workspace-mode vm run and vm workspace prepare used to copy both tracked AND untracked non-ignored files into the guest. That silently catches local .env files, scratch notes, credentials, and any other working-tree state a developer hasn't explicitly gitignored — a real data-exposure footgun given the golden image ships Docker and the usual dev tooling. Flip the default to tracked-only. Users who actually want the fuller set opt in with --include-untracked (documented in both commands' help). Gitignored files are still always excluded regardless of the flag. Add --dry-run to both vm run and vm workspace prepare. Dry-run inspects the repo CLI-side (no VM created, no daemon RPC needed since the daemon is always local and the inspection is a pure git read), prints the exact file list + mode, and exits. A byte-level preview of what would land in the guest. When running real (non-dry) and untracked files exist in the repo but are being skipped under the new default, print a one-line notice pointing to --include-untracked so users aren't surprised when the guest is missing something they expected. Signature changes: - ListOverlayPaths takes an includeUntracked bool (tracked always; untracked gated by flag). - InspectRepo takes the same flag and passes it through. - VMWorkspacePrepareParams gains IncludeUntracked. - WorkspaceService.workspaceInspectRepo seam signature widened to match (4 callers in tests updated). New workspace package tests cover both modes and verify that gitignored files never leak regardless of the flag. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
25a1466947
commit
2a7f55f028
11 changed files with 293 additions and 67 deletions
19
README.md
19
README.md
|
|
@ -83,10 +83,14 @@ banger vm run --rm -- script.sh # ephemeral: VM is deleted on exit
|
|||
```
|
||||
|
||||
- **Bare mode** gives you a clean shell.
|
||||
- **Workspace mode** (path given) copies the repo's tracked + untracked
|
||||
non-ignored files into `/root/repo` and kicks off a best-effort
|
||||
`mise` tooling bootstrap from the repo's `.mise.toml` /
|
||||
`.tool-versions`. Log: `/root/.cache/banger/vm-run-tooling-<repo>.log`.
|
||||
- **Workspace mode** (path given) copies the repo's git-tracked files
|
||||
into `/root/repo` and kicks off a best-effort `mise` tooling
|
||||
bootstrap from the repo's `.mise.toml` / `.tool-versions`. Log:
|
||||
`/root/.cache/banger/vm-run-tooling-<repo>.log`. Untracked files
|
||||
(including local `.env`, scratch notes, credentials that aren't
|
||||
gitignored) are skipped by default — pass `--include-untracked` to
|
||||
also ship them. Pass `--dry-run` to print the exact file list and
|
||||
exit without creating a VM.
|
||||
- **Command mode** (`-- <cmd>`) runs the command in the guest; exit
|
||||
code propagates through `banger`.
|
||||
|
||||
|
|
@ -94,9 +98,10 @@ Disconnecting from an interactive session leaves the VM running. Use
|
|||
`vm stop` / `vm delete` to clean up — or pass `--rm` so the VM
|
||||
auto-deletes once the session / command exits.
|
||||
|
||||
`--branch` and `--from` apply only to workspace mode. `--rm` skips
|
||||
the delete when the initial ssh wait times out, so a wedged sshd
|
||||
leaves the VM alive for `banger vm logs` inspection.
|
||||
`--branch`, `--from`, `--include-untracked`, and `--dry-run` apply
|
||||
only to workspace mode. `--rm` skips the delete when the initial ssh
|
||||
wait times out, so a wedged sshd leaves the VM alive for `banger vm
|
||||
logs` inspection.
|
||||
|
||||
## Hostnames: reaching `<vm>.vm`
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue