First live run on PR #126 left the foreground shell stuck: Claude pushed the commit itself and then did not exit, so the supervisor code after it (push + ack + handled marker) never ran. Under cron that also holds the flock lock, freezing every later run, and the comment never gets marked handled (so it would be re-processed forever). - Wrap the Claude invocation in `setsid timeout -k 30s "$CLAUDE_TIMEOUT"` (default 30m). `setsid` detaches from the controlling terminal so a lingering child can't stick an interactive run; `timeout` returns control to the supervisor, which still pushes any commits (idempotent if Claude pushed) and writes the handled marker. A timed-out run (rc=124) is logged, not fatal. - Give this watcher its own dev port (devPort, default 3101) distinct from the issue watcher's 3100, and reap it after each run -- no cross-watcher kill. - Reinforce the prompt: stop any dev server and END THE TURN; never push. Adds claudeTimeout + devPort to the example config and documents both. Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
15 lines
469 B
JSON
15 lines
469 B
JSON
{
|
|
"forgejoUrl": "https://git.pelagiamarine.com",
|
|
"repo": "shad0w/pelagia-portal",
|
|
"token": "<forgejo token with write:repository,write:issue>",
|
|
"workDir": "/home/shad0w/pelagia-pr-review",
|
|
"baseBranch": "master",
|
|
"prBranchPrefix": "claude/",
|
|
"marker": "claude-review:",
|
|
"maxPrsPerRun": 1,
|
|
"maxCommentsPerPr": 20,
|
|
"claudeExe": "/home/shad0w/.nvm/versions/node/<ver>/bin/claude",
|
|
"claudeMaxTurns": 150,
|
|
"claudeTimeout": "30m",
|
|
"devPort": 3101
|
|
}
|