Commit bf0e34e
committed
fix(daemon): dispatcher skips idle dogs with leaked tmux sessions (gt-o24)
dispatchPlugins was calling mgr.GetIdleDog(), which returns the first idle
dog from mgr.List() in directory order. When a dog's registry state was
marked idle before its tmux session fully terminated (the window between
'gt dog done' setting StateIdle and tmux actually killing the session), the
daemon would pick that dog, send it plugin mail, then hit sm.Start failing
with "session already running: hq-dog-<name>". The failed assignment was
rolled back and the next heartbeat picked the same dog again — infinite loop
on one dog while the rest of the pack sat idle.
Fix: dispatchPlugins now iterates the kennel itself, skipping any dog whose
registry state is non-idle OR whose tmux session is already running per
sm.IsRunning. A transient termination race on one dog no longer blocks
dispatch to the other three; worst case the dispatcher defers one tick.
Extracted the filter into findDispatchableDog so it's unit-testable and
the intent is explicit at the call site.
Tests cover: idle-with-working-peer picks the idle one; all-working returns
nil; empty kennel returns nil; two idle dogs (no live sessions) pick one.
The "skip idle-with-live-session" regression path is exercised at runtime
via sm.IsRunning, whose tmux correctness is covered in session_manager tests.
Observed in production 2026-04-19: alpha locked the dispatcher for 20+
minutes while bravo/charlie/delta idle, ~14 plugin beads queued with
assignees but none pulled. Manual workaround was 'tmux kill-session -t
hq-dog-alpha'; with this fix the dispatcher advances on its own.
Closes gt-o24.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Executed-By: gastown/crew/woodhouse1 parent db74d75 commit bf0e34e
2 files changed
Lines changed: 122 additions & 7 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| 5 | + | |
5 | 6 | | |
6 | 7 | | |
7 | 8 | | |
| |||
256 | 257 | | |
257 | 258 | | |
258 | 259 | | |
259 | | - | |
260 | | - | |
261 | | - | |
262 | | - | |
263 | | - | |
264 | | - | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
265 | 268 | | |
266 | | - | |
| 269 | + | |
267 | 270 | | |
268 | 271 | | |
269 | 272 | | |
| |||
320 | 323 | | |
321 | 324 | | |
322 | 325 | | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
323 | 361 | | |
324 | 362 | | |
325 | 363 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
395 | 395 | | |
396 | 396 | | |
397 | 397 | | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
| 429 | + | |
| 430 | + | |
| 431 | + | |
| 432 | + | |
| 433 | + | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
| 437 | + | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
| 442 | + | |
| 443 | + | |
| 444 | + | |
| 445 | + | |
| 446 | + | |
| 447 | + | |
| 448 | + | |
| 449 | + | |
| 450 | + | |
| 451 | + | |
| 452 | + | |
| 453 | + | |
| 454 | + | |
| 455 | + | |
| 456 | + | |
| 457 | + | |
| 458 | + | |
| 459 | + | |
| 460 | + | |
| 461 | + | |
| 462 | + | |
| 463 | + | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
| 474 | + | |
0 commit comments