-
Notifications
You must be signed in to change notification settings - Fork 166
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: opt-in to "all" semantics when determining freight's availability to a given stage #3207
Comments
This is basically #1168. It went stale and got revived (by me) a few times, and the last time it went stale, I left it, simply because in all the time it had been open, it never got much traction. Personally, I agree 100% that this is a useful feature. Just no one's been asking for it. If you want to do some of the legwork on this, we'd certainly be grateful for that. A couple words of caution on revising Freight availability logic -- I've got some non-trivial refactoring of that going on in #3100. It's best to hold off on touching that so as not to invite some rough merge conflicts. We would also need the existing "any" semantics to remain the default, with "all" semantics as an opt-in, so that this won't be a breaking change... With that in mind, my best suggestion is to start by proposing whatever (non-breaking) modifications you think will be required to various resource types to enable this. That would be a great way to drive further discussion. Thanks for re-raising this and for your willingness to help make it happen! |
I'm still fresh with Kargo and the direction it's going, but here is a high level approach to implementing this: ScopeFrom the linked issue #1168, this feature is scoped to the use-case of auto promotions and shouldn't change the behaior of other types of promotion (ie direct Warehouse promotion or manual approvals). The existing any semantics for auto promotion will remain the default when Interface changesThe
The strategy names might benefit from being more explicit ie, 'upstream_stages_any' and 'upstream_stages_all'. There could also be other strategies implemented in the future, such as 'majority' (Freight is promoted when a majority of upstream Stages have verified it) or 'percentage' (Freight is promoted when a >X% of upstream Stages have verified it). The implemented behavior should be consistent for both 'regular Stages' and 'control flow Stages'. Here is an example Project which sets the
I don't believe the UI currently indicates if auto promotion is enabled - maybe that is a gap in UX right now but I don't think this feature would be the driver for any changes. All other resource types should be able to stay the same. ImplementationThis will likely change with the upcoming refactor, but right now I believe this could be implemented relatively simply within regular_stages.go and control_flow.go (and ideally de-duplicate this logic a bit). |
This seems like a good starting point. If I may suggest a refinement: I wouldn't want to see the option for this being in the Project resource. As I wrote in another thread:
... such as opting into different availability semantics. I think a more appropriate place to put this might be in the My other suggestion is to keep the word "promotion" out of this as much as we can, and especially keep the words "auto promotion" out of this. I totally get that preventing what you consider pre-mature autopromotion was the impetus for opening this issue, but I'd want the rules for what Freight is available to a given Stage to be consistent regardless of whether a Promotion were automatic or manual. Maybe "availabilityStrategy" or something like that?
I think there's a little robot head icon on the Stage if it's enabled. Once again, thank you so much for your willingness to collaborate on this! |
With #3100 now merged, I'll re-structure my implementation to fit and then open a draft PR for initial feedback. |
Thanks @aidan-canva! I planned to call your attention to that having been merged, but it seems you were watching it. 👏 |
Just checking if you saw the linked PR @krancour - keen to hear your thoughts and hopefully move it towards being merged. |
Checklist
kargo version
, if applicable.Note
I'm not actually sure if this is a feature request or a bug - the current functionality caught me by surprise though I could be biased based on my personal use-case.
I've searched the docs, issues, discussions and Discord and I couldn't find any mention of this behavior. I've also read through parts of the code-base to determine if this feature request is supported but not documented. I've found reference to the ControlFlow concept, but it doesn't support any extra customization at present.
Please let me know if this use-case is solvable using existing constructs.
Proposed Feature
(Optionally?) Freight should only be promoted to a downstream Stage when all upstream Stages have successfully verified it.
Motivation
In our environment we have a large number of Stages (each represents a different cluster/environment). Stages are grouped based on risk profile (think: dev, staging, prod) where we would like each Stage in a 'group' to receive a Freight in parallel. Each Stage then runs their own verification process (potentially different / more exhaustive per-Stage). Each Stage also has
autoPromotionEnabled
- we are relying on the verifications to ensure a safe promotion.If a single Stage fails to verify a given Freight, it indicates something needs to be investigated and possibly fixed and as a result, the Freight should not be promoted further as it could fail in more critical environments.
In a simple Kargo Pipeline with no parallel steps, the above behavior works as expected: eg:
In pipelines that have 'parallel' Stages, Freight will be promoted to a downstream Stage if any single upstream Stage has verified it:
If Freight
aaaaaa
passed verification inStage-StagingA
but fails inStage-StagingB
,Stage-Prod
will receive the Freight.Suggested Implementation
I am struggling to think of use-cases where the current functionality is the preferred behavior which is making me lean towards this being a bug rather than a feature. If its a bug, I have a small working POC that changes the getAvailableFreight method in a ControlFlow Stage to only return Freight verified by all upstream Stages. Assumably, the same logic could be applied to a regular Stage.
If this is a feature, then I imagine the same logic would be suitable but would need to be configurable - ideally per-Stage. Though maybe this is only a 'bug' when
autoPromotionEnabled
is set on a Stage and this behavior is otherwise expected?Let me know if opening a draft PR helps to understand the problem better.
The text was updated successfully, but these errors were encountered: