chore: gardener housekeeping 2026-03-25
This commit is contained in:
parent
6afc7f183f
commit
b8dc01b06f
11 changed files with 76 additions and 47 deletions
|
|
@ -1,21 +1,22 @@
|
|||
<!-- last-reviewed: a2016db5c35ee3429ebaa212192983a03c4e4cb8 -->
|
||||
<!-- last-reviewed: 6afc7f183ffd831edae1a6c3f9d92e2094f2b998 -->
|
||||
# Dev Agent
|
||||
|
||||
**Role**: Implement issues autonomously — write code, push branches, address
|
||||
CI failures and review feedback.
|
||||
|
||||
**Trigger**: `dev-poll.sh` runs every 10 min via cron. It performs a direct-merge
|
||||
scan first (approved + CI green PRs — including chore/gardener PRs without issue
|
||||
numbers), then checks the agent lock and scans for ready issues using a two-tier
|
||||
priority queue: (1) `priority`+`backlog` issues first (FIFO within tier), then
|
||||
(2) plain `backlog` issues (FIFO). Orphaned in-progress issues are also picked up.
|
||||
The direct-merge scan runs before the lock check so approved PRs get merged even
|
||||
while a dev-agent session is active on another issue.
|
||||
**Trigger**: `dev-poll.sh` runs every 10 min via cron. Sources `lib/guard.sh` and
|
||||
calls `check_active dev` first — skips if `$FACTORY_ROOT/state/.dev-active` is
|
||||
absent. Then performs a direct-merge scan (approved + CI green PRs — including
|
||||
chore/gardener PRs without issue numbers), then checks the agent lock and scans
|
||||
for ready issues using a two-tier priority queue: (1) `priority`+`backlog` issues
|
||||
first (FIFO within tier), then (2) plain `backlog` issues (FIFO). Orphaned
|
||||
in-progress issues are also picked up. The direct-merge scan runs before the lock
|
||||
check so approved PRs get merged even while a dev-agent session is active.
|
||||
|
||||
**Key files**:
|
||||
- `dev/dev-poll.sh` — Cron scheduler: finds next ready issue, handles merge/rebase of approved PRs, tracks CI fix attempts
|
||||
- `dev/dev-agent.sh` — Orchestrator: claims issue, creates worktree + tmux session with interactive `claude`, monitors phase file, injects CI results and review feedback, merges on approval
|
||||
- `dev/phase-handler.sh` — Phase callback functions: `post_refusal_comment()`, `_on_phase_change()`, `build_phase_protocol_prompt()`. `do_merge()` detects already-merged PRs on HTTP 405 (race with dev-poll's pre-lock scan) and returns success instead of escalating
|
||||
- `dev/phase-handler.sh` — Phase callback functions: `post_refusal_comment()`, `_on_phase_change()`, `build_phase_protocol_prompt()`. `do_merge()` detects already-merged PRs on HTTP 405 (race with dev-poll's pre-lock scan) and returns success instead of escalating. Sources `lib/mirrors.sh` and calls `mirror_push()` after every successful merge. Matrix escalation notifications include `MATRIX_MENTION_USER` HTML mention when set.
|
||||
- `dev/phase-test.sh` — Integration test for the phase protocol
|
||||
|
||||
**Environment variables consumed** (via `lib/env.sh` + project TOML):
|
||||
|
|
@ -27,6 +28,10 @@ while a dev-agent session is active on another issue.
|
|||
- `CLAUDE_TIMEOUT` — Max seconds for a Claude session (default 7200)
|
||||
- `MATRIX_TOKEN`, `MATRIX_ROOM_ID`, `MATRIX_HOMESERVER` — Notifications (optional)
|
||||
|
||||
**Lifecycle**: dev-poll.sh → dev-agent.sh → create Matrix thread + export
|
||||
`MATRIX_THREAD_ID` (streams Claude output to thread via Stop hook) → tmux
|
||||
`dev-{project}-{issue}` → phase file drives CI/review loop → merge → close issue.
|
||||
**Lifecycle**: dev-poll.sh (`check_active dev`) → dev-agent.sh → create Matrix
|
||||
thread + export `MATRIX_THREAD_ID` → tmux `dev-{project}-{issue}` → phase file
|
||||
drives CI/review loop → merge + `mirror_push()` → close issue. On respawn after
|
||||
`PHASE:escalate`, the stale phase file is cleared first so the session starts
|
||||
clean; the reinject prompt tells Claude not to re-escalate for the same reason.
|
||||
On respawn for any active PR, the prompt explicitly tells Claude the PR already
|
||||
exists and not to create a new one via API.
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue