Commit c3e3d7c
authored
fix: call manage_relationships in single hard destroy path (#2596)
The single hard destroy path in `destroy.ex` never called
`manage_relationships`, causing any `manage_relationship` changes
declared on hard destroy actions to be silently ignored. The bulk
destroy, soft destroy, create, and update paths all properly called
`manage_relationships`.
Adds `manage_relationships/4` to `Ash.Actions.Destroy` following the
same pattern used in `Ash.Actions.Update`, and pipes the data layer
result through it before the notification/select pipeline.
Also adds comprehensive tests for manage_relationship on destroy
actions: single hard destroy, single soft destroy, bulk hard destroy,
and bulk soft destroy.
Closes ash-project/ash_postgres#7021 parent 3edbaee commit c3e3d7c
File tree
4 files changed
+432
-3
lines changed- lib/ash
- actions/destroy
- error/unknown
- test
4 files changed
+432
-3
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
242 | 242 | | |
243 | 243 | | |
244 | 244 | | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
245 | 249 | | |
246 | 250 | | |
247 | | - | |
| 251 | + | |
248 | 252 | | |
249 | | - | |
| 253 | + | |
250 | 254 | | |
251 | 255 | | |
252 | 256 | | |
| |||
257 | 261 | | |
258 | 262 | | |
259 | 263 | | |
260 | | - | |
| 264 | + | |
261 | 265 | | |
262 | 266 | | |
263 | 267 | | |
| |||
304 | 308 | | |
305 | 309 | | |
306 | 310 | | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
307 | 342 | | |
308 | 343 | | |
309 | 344 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
1 | 5 | | |
2 | 6 | | |
3 | 7 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
1 | 5 | | |
2 | 6 | | |
3 | 7 | | |
| |||
0 commit comments