HCL
4a870300dd
fix(update-cli): capture macOS launchctl stderr to a log file instead of /dev/null
...
The macOS restart helper emitted by `openclaw update` (darwin branch of
`prepareRestartScript`) wrote the gateway restart script with every
`launchctl` stderr redirected to `/dev/null` and the final fallback
`kickstart` chained with `|| true`. When bootstrap/kickstart failed
(plist-on-disk race, schema rejection, stale job, bootout recovery
edge cases), the script exited 0, the updater declared success, and
the gateway silently stayed offline.
The reporter saw a ~25 minute production outage before noticing the
messages going unanswered across Telegram/Discord/Feishu.
Route stderr to `~/.openclaw/logs/update-restart.log` via `exec 2>>`,
drop `2>/dev/null` on every launchctl call, and remove the `|| true`
swallow on the fallback kickstart so a genuine failure exits non-zero
and leaves a durable audit trail. Log directory creation is best-effort
via `mkdir -p ... 2>/dev/null || true` since it normally already exists
from the gateway's own logging path. Self-cleanup of the script file
via `rm -f "$0"` is retained because the log, not the script, is the
useful artifact after the fact.
Adds a targeted regression test `captures macOS launchctl stderr to
~/.openclaw/logs/update-restart.log` alongside the existing darwin
restart-script test. The existing test's assertions about the
kickstart/enable/bootstrap fallback chain + self-cleanup all still pass.
Fixes #68486
2026-04-18 18:39:03 +01:00
..
2026-04-08 01:36:38 +01:00
2026-04-18 18:31:13 +01:00
2026-04-18 18:31:13 +01:00
2026-04-11 01:27:48 +01:00
2026-04-11 18:36:48 +01:00
2026-04-18 18:31:13 +01:00
2026-04-17 02:17:56 -04:00
2026-03-08 03:02:25 +00:00
2026-04-18 18:39:03 +01:00
2026-03-31 02:25:02 +01:00
2026-04-08 15:58:45 +01:00
2026-04-06 14:16:03 +01:00
2026-04-06 14:16:03 +01:00
2026-03-30 00:41:06 +01:00
2026-03-26 22:00:13 +00:00
2026-04-06 22:21:01 +01:00
2026-04-06 22:21:01 +01:00
2026-04-06 22:21:01 +01:00
2026-04-12 14:04:44 -07:00
2026-04-18 16:15:33 +01:00
2026-03-30 00:39:39 +01:00
2026-04-08 01:36:38 +01:00
2026-04-04 01:07:28 +09:00
2026-04-04 01:07:28 +09:00
2026-04-18 16:32:53 +01:00
2026-03-31 02:25:02 +01:00
2026-04-18 18:31:13 +01:00
2026-04-06 13:51:51 +01:00
2026-04-06 13:51:51 +01:00
2026-04-07 03:46:24 +01:00
2026-04-13 20:56:03 +01:00
2026-04-06 07:41:08 +01:00
2026-04-06 07:41:08 +01:00
2026-04-06 14:16:03 +01:00
2026-04-06 14:16:03 +01:00
2026-04-08 18:03:03 +02:00
2026-04-18 18:31:13 +01:00
2026-04-06 15:38:04 +01:00
2026-04-06 15:38:04 +01:00
2026-04-07 03:37:15 +01:00
2026-04-11 02:15:21 +01:00
2026-04-08 11:47:59 +01:00
2026-04-08 11:47:59 +01:00
2026-04-07 03:02:41 +08:00
2026-04-11 18:36:48 +01:00
2026-04-17 16:05:10 +01:00
2026-04-07 02:58:10 +08:00
2026-04-14 17:59:28 -05:00
2026-04-14 17:59:28 -05:00
2026-03-22 22:47:58 +00:00
2026-03-22 22:47:58 +00:00
2026-04-06 13:51:51 +01:00
2026-04-06 14:16:03 +01:00
2026-04-07 19:59:51 +08:00
2026-04-11 12:53:56 +01:00
2026-04-11 12:53:56 +01:00
2026-04-10 11:45:28 +01:00
2026-04-12 11:52:56 -07:00
2026-04-11 15:48:58 +10:00
2026-04-13 20:40:52 +01:00
2026-03-17 20:20:11 -05:00
2026-03-28 00:46:53 +00:00
2026-04-08 01:36:38 +01:00
2026-03-17 18:15:49 -05:00
2026-03-17 18:15:49 -05:00
2026-03-25 00:51:55 -04:00
2026-04-11 00:39:04 +01:00
2026-04-18 18:31:13 +01:00
2026-04-14 17:35:26 +01:00
2026-04-14 17:35:26 +01:00
2026-04-18 18:31:13 +01:00
2026-04-03 19:09:21 +01:00
2026-04-11 13:26:50 +01:00
2026-04-11 13:26:50 +01:00
2026-04-11 02:55:01 +01:00
2026-04-11 18:36:48 +01:00
2026-03-31 02:25:02 +01:00
2026-04-08 01:36:38 +01:00
2026-03-30 16:10:13 +01:00
2026-04-04 18:24:29 -07:00
2026-04-14 11:29:59 +05:30
2026-04-14 11:29:59 +05:30
2026-04-10 12:14:36 +01:00
2026-04-11 13:26:50 +01:00
2026-04-03 19:10:56 +01:00
2026-04-11 18:36:48 +01:00
2026-04-10 09:00:19 +01:00
2026-04-10 09:00:19 +01:00
2026-04-08 15:58:45 +01:00
2026-03-26 19:16:43 +00:00
2026-04-11 13:26:50 +01:00
2026-03-02 19:57:33 +00:00
2026-03-28 00:46:53 +00:00
2026-04-04 01:07:28 +09:00
2026-04-04 00:28:25 +01:00
2026-04-11 01:27:48 +01:00
2026-03-31 02:25:02 +01:00
2026-04-08 15:58:45 +01:00
2026-03-27 21:50:39 +00:00
2026-04-07 09:44:53 +01:00
2026-03-31 02:25:02 +01:00
2026-04-06 13:42:44 +01:00
2026-03-31 02:25:02 +01:00
2026-03-02 23:32:41 +00:00
2026-04-03 20:34:23 +01:00
2026-04-07 02:03:33 +01:00
2026-03-29 09:10:38 +01:00
2026-03-02 19:57:33 +00:00
2026-04-11 13:42:17 +01:00
2026-04-03 19:53:38 +01:00
2026-04-11 10:43:22 +01:00
2026-03-31 02:25:02 +01:00
2026-04-11 21:16:50 +01:00
2026-04-08 01:36:38 +01:00
2026-04-08 01:36:38 +01:00
2026-03-14 01:41:16 +00:00
2026-03-14 01:41:16 +00:00
2026-04-03 19:09:20 +01:00
2026-03-29 09:10:38 +01:00
2026-03-23 18:08:17 +02:00
2026-04-14 17:59:28 -05:00
2026-04-14 17:59:28 -05:00
2026-04-12 18:40:04 +01:00
2026-04-03 19:09:20 +01:00
2026-04-18 18:31:13 +01:00
2026-04-15 13:23:17 +08:00
2026-04-11 08:22:36 +01:00
2026-04-11 13:26:50 +01:00
2026-04-11 08:12:34 +01:00
2026-04-11 08:08:41 +01:00
2026-04-11 13:26:50 +01:00
2026-04-15 13:23:17 +08:00
2026-04-04 04:26:51 +09:00
2026-04-11 13:26:50 +01:00
2026-04-11 08:08:41 +01:00
2026-04-11 08:22:36 +01:00
2026-04-11 08:22:36 +01:00
2026-04-11 08:12:34 +01:00
2026-04-11 13:26:50 +01:00
2026-04-11 08:08:41 +01:00
2026-04-11 08:08:41 +01:00
2026-04-11 08:08:41 +01:00
2026-04-03 19:54:37 +01:00
2026-04-07 02:03:34 +01:00
2026-04-07 17:50:38 +01:00
2026-04-08 18:03:03 +02:00
2026-04-08 01:36:38 +01:00
2026-03-02 08:33:59 -06:00
2026-04-12 16:08:12 +01:00
2026-04-10 21:53:47 +01:00
2026-03-31 02:25:02 +01:00
2026-04-12 16:08:12 +01:00
2026-03-31 02:25:02 +01:00
2026-04-07 13:01:23 +01:00
2026-04-11 12:34:57 -05:00
2026-04-11 12:34:57 -05:00
2026-04-11 12:34:57 -05:00
2026-04-11 12:34:57 -05:00
2026-04-04 16:55:04 +09:00
2026-04-13 15:12:01 +01:00
2026-04-07 01:16:15 +01:00
2026-04-06 14:16:03 +01:00
2026-04-04 02:35:36 +01:00
2026-03-26 18:34:51 +00:00
2026-03-24 21:00:36 +00:00
2026-04-08 00:30:22 +01:00
2026-04-06 14:16:03 +01:00
2026-04-08 11:47:59 +01:00
2026-04-03 19:10:56 +01:00
2026-04-12 19:14:00 +01:00
2026-04-12 11:28:43 -07:00
2026-03-31 02:25:02 +01:00
2026-03-22 23:19:17 +00:00
2026-03-31 02:25:02 +01:00
2026-04-08 01:36:38 +01:00
2026-04-04 18:09:44 +03:00
2026-03-30 16:10:13 +01:00
2026-03-28 03:45:56 +00:00
2026-03-30 16:10:13 +01:00
2026-04-07 07:36:11 +01:00
2026-04-03 20:34:23 +01:00
2026-04-08 01:36:38 +01:00
2026-03-03 00:31:51 +00:00
2026-03-03 00:31:51 +00:00
2026-04-18 18:31:13 +01:00
2026-03-31 02:25:02 +01:00
2026-04-04 16:55:04 +09:00
2026-04-04 16:55:04 +09:00
2026-04-15 13:22:04 +05:30
2026-03-22 15:09:38 -07:00
2026-04-08 01:36:38 +01:00
2026-04-07 17:50:38 +01:00