Ernest Hysa
996a2027dd
Cookbook: surface pip install failures in logs
...
_pip_install_fallback_chain silently discarded pip stderr via
2>/dev/null on every attempt. When pip failed (network error, venv
mismatch, disk full), the wrapper exited 0 and the Cookbook UI showed
the download as running — the silent-failure mode from #354 .
Extract _pip_install_attempt() which wraps each pip invocation in a
bash -c subshell that captures output to a temp file, prints tail -5
on failure, cleans up, and exits with pip's real exit code. This
avoids the | tail pipefail masking (the first blocker on #363 ) while
surfacing the last 5 lines of pip output in the tmux log so users
can see what went wrong.
Both local wrapper and remote SSH runner use the same helper through
_pip_install_fallback_chain, so the fix is symmetric.
2026-06-02 20:34:52 +09:00
..
2026-05-31 23:58:26 +09:00
2026-05-31 23:58:26 +09:00
2026-06-01 14:32:41 +09:00
2026-06-02 13:06:09 +09:00
2026-06-02 20:28:26 +09:00
2026-06-02 01:32:00 +02:00
2026-06-01 02:22:17 +00:00
2026-06-02 05:48:59 +09:00
2026-06-02 12:26:12 +09:00
2026-06-02 06:02:49 +09:00
2026-06-02 05:55:03 +09:00
2026-06-02 12:40:28 +09:00
2026-06-02 05:48:59 +09:00
2026-06-01 13:42:44 +09:00
2026-06-01 22:33:35 +09:00
2026-06-01 22:22:41 +09:00
2026-06-02 20:29:37 +09:00
2026-06-02 13:15:22 +09:00
2026-06-01 22:24:27 +09:00
2026-06-01 12:38:35 +09:00
2026-06-02 12:59:29 +09:00
2026-06-02 20:34:52 +09:00
2026-06-02 12:25:56 +09:00
2026-06-02 11:50:03 +09:00
2026-06-02 20:34:25 +09:00
2026-06-02 12:41:25 +09:00
2026-06-02 11:48:54 +09:00
2026-06-02 06:00:02 +09:00
2026-06-02 20:28:01 +09:00
2026-06-02 13:15:06 +09:00
2026-06-02 11:10:43 +09:00
2026-06-01 14:23:22 -04:00
2026-06-02 20:32:56 +09:00
2026-06-02 20:34:05 +09:00
2026-06-01 22:35:24 +09:00
2026-06-02 11:36:01 +09:00
2026-06-01 22:47:47 +09:00
2026-06-02 13:07:20 +09:00
2026-06-02 11:12:54 +09:00
2026-06-02 11:14:31 +09:00
2026-06-02 05:54:23 +09:00
2026-06-02 11:37:25 +09:00
2026-06-02 20:27:24 +09:00
2026-06-02 11:48:17 +09:00
2026-06-02 11:17:22 +09:00
2026-06-02 11:39:40 +09:00
2026-06-02 11:47:58 +09:00
2026-06-02 11:49:44 +09:00
2026-06-02 11:28:52 +09:00
2026-06-02 11:50:17 +09:00
2026-06-02 11:46:06 +09:00
2026-06-02 11:27:31 +09:00
2026-06-02 20:33:09 +09:00
2026-06-02 20:34:40 +09:00
2026-06-02 20:31:35 +09:00
2026-06-02 11:41:33 +09:00
2026-06-02 12:24:18 +09:00
2026-06-01 18:27:17 +09:00
2026-06-02 11:28:52 +09:00
2026-06-01 22:33:35 +09:00
2026-06-01 22:36:53 +09:00
2026-06-02 20:32:08 +09:00
2026-06-02 11:11:17 +09:00
2026-06-02 12:53:50 +09:00
2026-05-31 23:58:26 +09:00
2026-06-02 11:42:20 +09:00
2026-06-02 11:30:53 +09:00
2026-06-02 11:27:31 +09:00
2026-06-01 23:25:38 +01:00
2026-06-01 22:26:37 +09:00
2026-06-02 05:58:58 +09:00
2026-06-02 12:24:50 +09:00
2026-06-02 20:29:47 +09:00
2026-06-02 11:43:30 +09:00
2026-06-02 10:53:33 +09:00
2026-06-01 23:09:41 +09:00
2026-05-31 23:58:26 +09:00
2026-06-02 20:29:56 +09:00
2026-06-02 12:34:42 +09:00
2026-06-01 16:55:09 +09:00
2026-06-02 11:39:01 +09:00
2026-06-01 23:11:50 +09:00
2026-06-01 22:38:56 +09:00
2026-06-02 12:23:29 +09:00
2026-06-02 11:15:45 +09:00
2026-06-02 20:28:36 +09:00
2026-06-02 11:21:27 +09:00
2026-06-02 10:44:39 +09:00
2026-06-02 11:29:29 +09:00
2026-06-02 20:32:20 +09:00
2026-06-02 11:42:04 +09:00
2026-06-02 12:57:45 +09:00
2026-06-02 12:25:43 +09:00
2026-06-01 13:09:21 +09:00
2026-06-01 22:26:13 +09:00
2026-06-02 20:28:12 +09:00
2026-06-02 11:23:40 +09:00