Commit 317a455
committed
fix: freight soak time verification with unrelated and control-flow stages
Auto-promotion could either incorrectly pass or permanently stall the
soak time gate (Stage.spec.requestedFreight[].sources.requiredSoakTime),
depending on the upstream Stage topology. Two distinct problems are
addressed:
1. Soak accrued in unrelated Stages satisfied the gate.
ListFreightFromWarehouse iterated over every Stage in the Freight's
status.verifiedIn map when checking whether the required soak time
had elapsed. Soak time accumulated in Stages that were NOT named as
upstream sources could therefore satisfy the requirement, letting
Freight promote before it had actually soaked in the configured
upstream Stage(s). Restrict the check to the Stages named in the
source's `stages` list (opts.VerifiedIn).
2. A control-flow upstream Stage could never satisfy the gate.
Control-flow Stages verify Freight without ever holding it: the
Freight is never added to status.currentlyIn and no completed soak is
ever recorded. GetLongestSoak only consulted those two fields, so it
returned 0 for a control-flow Stage no matter how long ago the Freight
was verified there. With problem 1 fixed, a downstream Stage whose
upstream source is a control-flow Stage could then never pass its
requiredSoakTime, and auto-promotion stalled indefinitely.
When neither a current residency nor a completed soak is recorded for
a Stage in which the Freight is verified -- which uniquely identifies
a control-flow Stage -- measure the soak from the Freight's verifiedAt
timestamp instead. Regular Stages always have one of the two records,
so their behavior is unchanged.
Refs: #4586
Signed-off-by: Justin Chen <mail@justin0u0.com>1 parent f791a1f commit 317a455
4 files changed
Lines changed: 93 additions & 7 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
153 | 153 | | |
154 | 154 | | |
155 | 155 | | |
156 | | - | |
| 156 | + | |
| 157 | + | |
157 | 158 | | |
158 | 159 | | |
159 | 160 | | |
160 | | - | |
| 161 | + | |
161 | 162 | | |
162 | 163 | | |
163 | 164 | | |
164 | | - | |
165 | | - | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
166 | 176 | | |
167 | 177 | | |
168 | 178 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
316 | 316 | | |
317 | 317 | | |
318 | 318 | | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
319 | 334 | | |
320 | 335 | | |
321 | 336 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
225 | 225 | | |
226 | 226 | | |
227 | 227 | | |
228 | | - | |
229 | | - | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
230 | 232 | | |
231 | | - | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
232 | 237 | | |
233 | 238 | | |
234 | 239 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
452 | 452 | | |
453 | 453 | | |
454 | 454 | | |
| 455 | + | |
| 456 | + | |
| 457 | + | |
| 458 | + | |
| 459 | + | |
| 460 | + | |
| 461 | + | |
| 462 | + | |
| 463 | + | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
| 474 | + | |
| 475 | + | |
| 476 | + | |
| 477 | + | |
| 478 | + | |
| 479 | + | |
| 480 | + | |
| 481 | + | |
| 482 | + | |
| 483 | + | |
| 484 | + | |
| 485 | + | |
| 486 | + | |
| 487 | + | |
| 488 | + | |
| 489 | + | |
| 490 | + | |
| 491 | + | |
| 492 | + | |
| 493 | + | |
| 494 | + | |
| 495 | + | |
| 496 | + | |
| 497 | + | |
| 498 | + | |
| 499 | + | |
| 500 | + | |
| 501 | + | |
| 502 | + | |
| 503 | + | |
| 504 | + | |
| 505 | + | |
| 506 | + | |
| 507 | + | |
| 508 | + | |
| 509 | + | |
| 510 | + | |
455 | 511 | | |
456 | 512 | | |
457 | 513 | | |
| |||
0 commit comments