Commit bd2a28a
fix(mcp): tear down resources when startup fails after initialization (RAAE-1604)
Move binding teardown into startup()'s exception handler so it covers every
post-begin failure, not just failures inside _initialize_runtime_resources.
Previously, if initialization succeeded (clients connected, tools registered)
and a later step such as _mark_running() raised, the handler marked the server
stopped without tearing down, leaking Redis clients and vectorizers; a later
shutdown() saw STOPPED and skipped cleanup.
_initialize_runtime_resources no longer needs its own teardown (a binding that
fails mid-build still closes its bare client inside _initialize_binding), giving
a single fail-closed teardown path. Add a regression test for the
init-succeeds-then-post-step-fails case.
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>1 parent 96f42c3 commit bd2a28a
2 files changed
Lines changed: 53 additions & 11 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
97 | 97 | | |
98 | 98 | | |
99 | 99 | | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
100 | 106 | | |
101 | 107 | | |
102 | 108 | | |
| |||
400 | 406 | | |
401 | 407 | | |
402 | 408 | | |
403 | | - | |
404 | | - | |
405 | | - | |
406 | | - | |
407 | | - | |
408 | | - | |
409 | | - | |
410 | | - | |
411 | | - | |
412 | | - | |
413 | | - | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
414 | 417 | | |
415 | 418 | | |
416 | 419 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
223 | 223 | | |
224 | 224 | | |
225 | 225 | | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
226 | 265 | | |
227 | 266 | | |
228 | 267 | | |
| |||
0 commit comments