Closes the "needs heavy integration smoke" follow-up from the
ADR-002 commit (423a381). Until now the per-prefix PUT cap was
verified only by unit tests + commits' theory; this smoke runs
the actual cap path with real bytes.
Three assertions, ~2s wall:
1. PUT 300 MiB to _vectors/<key> → 200 (cap raised to 4 GiB
for the vectord persistence prefix).
2. PUT same 300 MiB to datasets/<key> → 413 (default 256 MiB
cap still protects routine traffic).
3. GET _vectors/<key> → sha256 round-trips (no truncation
between cap-raise and S3 multipart streaming).
scripts/storaged_cap_smoke.sh
Builds storaged + gateway, boots them, generates 300 MiB
deterministic /dev/zero payload (sha stable across runs),
runs the 3 assertions, cleans up the keys + processes via trap.
/dev/zero generation chosen over yes/head pipe — pipefail
catches the SIGPIPE from yes when head closes early.
just smoke-storaged-cap
Wrapper recipe. Outside the main `just verify` chain because
300 MiB payload generation + transfer is MB-heavy. Run after
meaningful storaged or vectord-persistence changes.
Verified:
bash scripts/storaged_cap_smoke.sh — 3/3 PASS · 2s wall
just verify — vet + test + 9 smokes still 33s
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
124 lines
4.3 KiB
Makefile
124 lines
4.3 KiB
Makefile
# golangLAKEHOUSE — task runner.
|
|
#
|
|
# Sprint 0 acceptance gate (R-004): smokes are no longer documentation
|
|
# only — `just verify` is the single command that runs vet + tests +
|
|
# the 9 smokes. The pre-push hook calls this; CI calls this; reviewers
|
|
# call this. One source of truth.
|
|
#
|
|
# Usage:
|
|
# just # alias for `just --list`
|
|
# just verify # vet + test + all 9 smokes (full gate)
|
|
# just smoke <day> # single smoke (d1..d6, g1, g1p, g2)
|
|
# just smoke-all # all 9 smokes only
|
|
# just doctor # dependency probe
|
|
# just fmt / vet / test / build
|
|
|
|
# Go lives at /usr/local/go/bin per ADR-001 §1.x; prepend so every
|
|
# recipe sees it without depending on the parent shell's PATH.
|
|
export PATH := "/usr/local/go/bin:" + env('PATH', '')
|
|
|
|
# Default recipe shows the menu so `just` alone is a discoverable entry point.
|
|
default:
|
|
@just --list
|
|
|
|
# Full Sprint 0 gate: vet + tests + 9 smokes. Pre-push hook calls this.
|
|
verify: vet test smoke-all
|
|
@echo ""
|
|
@echo "[verify] PASS — go vet + go test + 9 smokes all green"
|
|
|
|
# Static analysis. Runs first so we fail fast on syntax / shape issues.
|
|
vet:
|
|
@echo "[vet] go vet ./..."
|
|
@go vet ./...
|
|
|
|
# Go unit tests, short mode. Excludes hardware-in-the-loop tags.
|
|
test:
|
|
@echo "[test] go test -short -count=1 ./..."
|
|
@go test -short -count=1 ./...
|
|
|
|
# Format Go source. Idempotent; CI can run with --check via `just fmt-check`.
|
|
fmt:
|
|
@gofmt -w cmd internal scripts
|
|
|
|
# Verify formatting without modifying. Non-zero exit means run `just fmt`.
|
|
fmt-check:
|
|
@diff -u <(echo -n) <(gofmt -d cmd internal scripts)
|
|
|
|
# Build every binary into bin/. Mirrors what each smoke does internally.
|
|
build:
|
|
@echo "[build] go build -o bin/ ./cmd/..."
|
|
@go build -o bin/ ./cmd/...
|
|
|
|
# Single smoke. Day is the suffix before _smoke.sh — d1, d2, …, g2.
|
|
smoke day:
|
|
@bash scripts/{{day}}_smoke.sh
|
|
|
|
# Fixture-mode G2 smoke — runs against fake Ollama instead of real,
|
|
# so CI / fresh-clone reviewers without Ollama can verify the embed
|
|
# contract. Closes R-006 partial (embed half; storage half deferred).
|
|
smoke-g2-fixtures:
|
|
@bash scripts/g2_smoke_fixtures.sh
|
|
|
|
# Storaged cap smoke — verifies ADR-002's per-prefix PUT cap at 300 MiB.
|
|
# Outside the main chain (MB-heavy, ~5-10s wall); run after meaningful
|
|
# storaged or vectord-persistence changes.
|
|
smoke-storaged-cap:
|
|
@bash scripts/storaged_cap_smoke.sh
|
|
|
|
# All 9 smokes in dependency order. Halts on first failure.
|
|
smoke-all:
|
|
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
for day in d1 d2 d3 d4 d5 d6 g1 g1p g2; do
|
|
printf "[smoke-all] %s ... " "$day"
|
|
SECONDS=0
|
|
if bash "scripts/${day}_smoke.sh" >/tmp/smoke_${day}.log 2>&1; then
|
|
printf "PASS (%ss)\n" "$SECONDS"
|
|
else
|
|
printf "FAIL (%ss)\n" "$SECONDS"
|
|
echo ""
|
|
echo " last 20 lines of /tmp/smoke_${day}.log:"
|
|
tail -20 "/tmp/smoke_${day}.log" | sed 's/^/ /'
|
|
exit 1
|
|
fi
|
|
done
|
|
|
|
# Dependency probe. Add --json for machine-readable output.
|
|
doctor *args:
|
|
@bash scripts/doctor.sh {{args}}
|
|
|
|
# Proof harness — claims-verification tier above the smoke chain.
|
|
# See tests/proof/README.md and docs/TEST_PROOF_SCOPE.md.
|
|
# just proof contract fast: APIs + status codes + dim/nonempty
|
|
# just proof integration full: CSV→Parquet→SQL, text→vector→search
|
|
# just proof performance measurements; runs only after contract+integration
|
|
proof mode *flags:
|
|
@bash tests/proof/run_proof.sh --mode {{mode}} {{flags}}
|
|
|
|
# Install pre-push hook so `git push` runs `just verify` first.
|
|
install-hooks:
|
|
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
HOOK=".git/hooks/pre-push"
|
|
cat > "$HOOK" <<'HOOK'
|
|
#!/usr/bin/env bash
|
|
# golangLAKEHOUSE pre-push hook (managed by `just install-hooks`).
|
|
# Runs the Sprint 0 gate before letting commits leave this machine.
|
|
set -e
|
|
cd "$(git rev-parse --show-toplevel)"
|
|
echo "[pre-push] running just verify ..."
|
|
if ! just verify; then
|
|
echo ""
|
|
echo "[pre-push] FAIL — push aborted. Fix the gate or use --no-verify (NOT recommended)."
|
|
exit 1
|
|
fi
|
|
HOOK
|
|
chmod +x "$HOOK"
|
|
echo "[install-hooks] $HOOK installed and executable"
|
|
|
|
# Clean built binaries + smoke logs. Does NOT touch reports/ or data/.
|
|
clean:
|
|
@rm -rf bin/
|
|
@rm -f /tmp/smoke_*.log
|
|
@echo "[clean] bin/ removed, smoke logs cleared"
|