Sebastien Tardif
66bbcfdade
fix(telegram): handle ENOENT race in spool drain recovery rename
...
Handle the Telegram isolated-polling spool recovery race where a stale `.processing` claim can disappear between discovery and the final rename back to pending. Recovery now treats `ENOENT` as benign and mirrors the existing duplicate-pending cleanup path for `EEXIST`, avoiding noisy drain-failure logs and spurious failure counters without changing claim ownership semantics.
Adds a regression test that removes the claim from inside `shouldRecover`, after recovery has discovered the entry and before the final rename path, so the old code would hit the reported `ENOENT` window.
Fixes #87847
Co-authored-by: Sebastien Tardif <sebtardif@ncf.ca >
2026-05-31 18:02:55 +01:00
..
2026-05-31 14:46:17 +01:00
2026-05-31 00:29:44 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 15:55:32 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 17:35:41 +01:00
2026-05-25 11:34:12 +03:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 19:02:16 +02:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 17:51:35 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 17:00:24 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 17:17:53 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 16:43:46 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 09:00:00 -07:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 16:52:11 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 17:38:13 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 17:38:10 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 08:16:11 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 17:51:22 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 17:07:41 +01:00
2026-05-31 16:41:24 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 09:32:52 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 18:02:55 +01:00
2026-05-31 14:46:17 +01:00
2026-05-27 19:24:04 +01:00
2026-05-31 16:58:46 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 17:28:58 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 15:53:14 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-31 14:46:17 +01:00
2026-05-16 12:38:51 +01:00
2026-05-26 23:09:56 +01:00
2026-05-31 15:53:14 +01:00
2026-05-27 12:41:10 +02:00