fix: setup wizard non-interactive safe, TUI script daemon detection + timing
Some checks failed
Deploy (Gitea) / deploy (push) Failing after 3s

This commit is contained in:
2026-05-05 14:26:27 -04:00
parent 9281e37c01
commit 23b8cfacd3
4 changed files with 76 additions and 22 deletions

View File

@@ -25,14 +25,35 @@ run_test() {
}
# ---- Setup ----
echo "Starting daemon..."
passepartout daemon &
DAEMON_PID=$!
sleep 3
# Check if daemon is already running (bash /dev/tcp, no nc needed)
if timeout 2 bash -c 'echo >/dev/tcp/127.0.0.1/9105' 2>/dev/null; then
echo "Daemon already running on port 9105"
DAEMON_PID=""
else
echo "Starting daemon..."
passepartout daemon &
DAEMON_PID=$!
for i in $(seq 1 10); do
sleep 2
if timeout 1 bash -c 'echo >/dev/tcp/127.0.0.1/9105' 2>/dev/null; then
echo " Daemon ready after $((i*2))s"
break
fi
done
fi
done
fi
echo "Starting TUI in tmux..."
tmux new-session -d -s tui-test "passepartout tui 2>&1 | tee $TUI_LOG"
sleep 4
# Wait for TUI to render: up to 30 seconds for Croatoan + daemon connect
for i in $(seq 1 15); do
sleep 2
if grep -q 'Connected v[0-9]' "$TUI_LOG" 2>/dev/null; then
echo " TUI ready after $((i*2))s"
break
fi
done
# ---- Tests ----
@@ -50,15 +71,15 @@ test_agent_responds() {
tmux send-keys -t tui-test "hello" Enter
# Wait up to 20 seconds for ⬇ to appear
# Wait up to 45 seconds for ⬇ to appear (LLM calls can be slow)
while true; do
if grep -q '⬇.*[a-zA-Z]\{3,\}' "$TUI_LOG"; then
return 0
fi
local now_ts
now_ts=$(date +%s)
if (( now_ts - before_ts > 20 )); then
echo "TIMEOUT: no agent response in log" >&2
if (( now_ts - before_ts > 45 )); then
echo "TIMEOUT: no agent response in log after 45s" >&2
return 1
fi
sleep 1
@@ -89,7 +110,12 @@ test_status_bar() {
}
test_connection_drop() {
kill $DAEMON_PID 2>/dev/null || true
# If we started the daemon, kill it. Otherwise kill by port.
if [ -n "$DAEMON_PID" ]; then
kill $DAEMON_PID 2>/dev/null || true
else
pkill -f "sbcl.*passepartout" 2>/dev/null || true
fi
sleep 3
grep -qi 'connection.*lost\|ERROR.*Connection' "$TUI_LOG"
}