fix(dispatcher): send a lone Enter after the task paste to submit it

Multi-line task bodies arrived in Claude Code as "[Pasted text #N +M lines]"
and sat in the input buffer forever — the trailing Enter that SendKeys
appends to the paste is consumed as a newline inside the paste, not as a
submit. Observed live on ccl-auto-11 (secumon) and ccl-auto-12 (secuops):
prompt visible, agent idle.

- tmux.Client grows a SendEnter(session) method. ExecClient runs
  `tmux send-keys -t <sess> Enter` (no preceding text), which Claude's
  TUI accepts as the explicit submit action after a paste.
- Dispatcher: after SendKeys(msg), sleep 500ms for the paste to register,
  then SendEnter. Same sequence a human would perform.
- Five mockTmux implementations updated (quota, dispatcher, switcher,
  lifecycle, watcher tests).

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Ubuntu 2026-04-15 20:49:59 +00:00
parent eb6b74c547
commit 6b109ed1bc
8 changed files with 72 additions and 3 deletions

View file

@ -40,6 +40,11 @@ func (m *mockTmux) SendKeys(session, keys string) error {
return nil
}
func (m *mockTmux) SendEnter(session string) error {
m.sendKeysCalls = append(m.sendKeysCalls, session)
return nil
}
func (m *mockTmux) CapturePaneTail(session string, lines int) (string, error) {
return "", nil
}