Commit 98b16b3
fix(webapp): explicit opt-in for mollifier stale-sweep + SYSTEM_FAILURE fallback on cancel-bifurcation
Two fixes from CodeRabbit on PR #3754:
1. `TRIGGER_MOLLIFIER_STALE_SWEEP_ENABLED` was inheriting
`TRIGGER_MOLLIFIER_ENABLED`, so any deployment already running the
mollifier would auto-start the sweep worker on upgrade — defeating
the point of having a separate kill switch. Hard-default to "0" so
the sweep is an explicit ops decision.
2. In the cancel-bifurcation path, a non-conflict + non-retryable
error from `createCancelledRun` rethrew out of the handler. The
drainer's `onTerminalFailure` handler gates on
`cause === "max-attempts-exhausted"` and skips "non-retryable", so
`buffer.fail()` deleted the entry without ever writing a PG row —
the cancelled run disappeared silently. Mirror the SYSTEM_FAILURE
fallback the non-cancel trigger path already uses: write a terminal
row via the shared helper, falling back to the original throw only
when the write also fails non-retryably (and re-throw retryable
write errors so the drainer requeues).
UX trade: the customer initiated a cancel but sees SYSTEM_FAILURE if
the cancel write itself was structurally rejected. Terminal-but-
mislabelled beats terminal silence — the alternative was the run
disappearing from the dashboard entirely. The path is narrow (only
non-conflict, non-retryable createCancelledRun failures).
Two new unit tests cover the cancel branch: non-retryable creates the
SYSTEM_FAILURE row + ACKs the entry; retryable rethrows so the
drainer requeues.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>1 parent 8cab7c8 commit 98b16b3
3 files changed
Lines changed: 125 additions & 7 deletions
File tree
- apps/webapp
- app
- v3/mollifier
- test
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1104 | 1104 | | |
1105 | 1105 | | |
1106 | 1106 | | |
1107 | | - | |
1108 | | - | |
1109 | | - | |
1110 | | - | |
1111 | | - | |
1112 | | - | |
1113 | | - | |
| 1107 | + | |
| 1108 | + | |
| 1109 | + | |
| 1110 | + | |
| 1111 | + | |
| 1112 | + | |
| 1113 | + | |
| 1114 | + | |
| 1115 | + | |
| 1116 | + | |
| 1117 | + | |
| 1118 | + | |
| 1119 | + | |
1114 | 1120 | | |
1115 | 1121 | | |
1116 | 1122 | | |
| |||
Lines changed: 33 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
103 | 103 | | |
104 | 104 | | |
105 | 105 | | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
106 | 139 | | |
107 | 140 | | |
108 | 141 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
348 | 348 | | |
349 | 349 | | |
350 | 350 | | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
| 365 | + | |
| 366 | + | |
| 367 | + | |
| 368 | + | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
| 429 | + | |
351 | 430 | | |
352 | 431 | | |
353 | 432 | | |
| |||
0 commit comments