Commit 893bed9
A repeated DELETE on a resource (retry, double-click, or concurrent
request) re-ran SoftDeleteResource and re-issued the backend deprovision
a second time. The second teardown races the first and can error against
an already-gone backend, surfacing a spurious 5xx for what is logically
a success.
Add an idempotent early-return after the team-ownership check: when the
resource is already status='deleted', report success
({"ok":true,"already_deleted":true,"id":...}) and do nothing. The first
DELETE already tore the backend down.
Test: TestResourceDelete_Idempotent_DoubleDelete — first DELETE → 200,
second DELETE → 200 with already_deleted=true. Verified against real
Postgres+Redis locally; runs in CI build-and-test.
Co-authored-by: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
1 parent 28e9332 commit 893bed9
2 files changed
Lines changed: 33 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
29 | 29 | | |
30 | 30 | | |
31 | 31 | | |
32 | | - | |
| 32 | + | |
33 | 33 | | |
34 | 34 | | |
35 | | - | |
36 | | - | |
37 | | - | |
38 | | - | |
39 | | - | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
40 | 40 | | |
41 | 41 | | |
42 | 42 | | |
| |||
1486 | 1486 | | |
1487 | 1487 | | |
1488 | 1488 | | |
| 1489 | + | |
| 1490 | + | |
| 1491 | + | |
| 1492 | + | |
| 1493 | + | |
| 1494 | + | |
| 1495 | + | |
| 1496 | + | |
| 1497 | + | |
| 1498 | + | |
| 1499 | + | |
| 1500 | + | |
| 1501 | + | |
| 1502 | + | |
| 1503 | + | |
| 1504 | + | |
| 1505 | + | |
| 1506 | + | |
| 1507 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
216 | 216 | | |
217 | 217 | | |
218 | 218 | | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
219 | 227 | | |
220 | 228 | | |
221 | 229 | | |
| |||
0 commit comments