Skip to content
This repository was archived by the owner on May 3, 2022. It is now read-only.

Bugfixes in release controller strategy executor #285

Merged

Conversation

osdrv
Copy link
Contributor

@osdrv osdrv commented Feb 19, 2020

This commit addresses multiple issues identified in strategy executor,
among which:

  • Wrong recepients for patch updates: due to an error in the code some
    patches were applied to a wrong generation of release and target
    objects.
  • Target object spec checkers used to return an incomplete spec if
    only some of the clusters are misbehaving: there was a risk of
    de-scheduling the workload on healthy clusters.

Signed-off-by: Oleg Sidorov oleg.sidorov@booking.com

@osdrv osdrv added the bug Something isn't working label Feb 19, 2020
@osdrv osdrv added this to the release-0.8 milestone Feb 19, 2020
@osdrv osdrv self-assigned this Feb 19, 2020
This commit addresses multiple issues identified in strategy executor,
among which:
  * Wrong recepients for patch updates: due to an error in the code some
  patches were applied to a wrong generation of release and target
  objects.
  * Target object spec checkers used to return an incomplete spec if
  only some of the clusters are misbehaving: there was a risk of
  de-scheduling the workload on healthy clusters.

Signed-off-by: Oleg Sidorov <oleg.sidorov@booking.com>
@osdrv osdrv force-pushed the olegs/fix-release-controller-order-of-strategy-steps branch from 4b197e1 to 58a116b Compare February 19, 2020 18:10
Copy link
Contributor

@hihilla hihilla left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM


switch action := a.(type) {

case kubetesting.CreateActionImpl:
extra := fmt.Sprintf("Name: %s\n", action.Name)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for this one. Debugging tests with multiple objects was driving me crazy too :D

HasIncumbent bool
IsLastStep bool
HasTail bool
Initiator *shipper.Release
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I get what the Initiator is after reading the code, but without being familiar with how things work I don't think that the name carries enough meaning. I'm sorry I don't have a better suggestion, so I'll still approve, and if a better name comes up we can have a PR just to rename this.

@juliogreff juliogreff merged commit 18e1839 into master Feb 20, 2020
@juliogreff juliogreff deleted the olegs/fix-release-controller-order-of-strategy-steps branch February 20, 2020 09:17
osdrv pushed a commit that referenced this pull request Feb 20, 2020
…tency

Due to a change introduced in #285, shipper strarted re-activating
historical releases due to the way targetStep is resolved. The
aforementioned step changed the composition of the pipeline and caused
historical releases to be re-scheduled. This caused some historical
items to re-activate their capacity and target targets. This change
mainly reverts the re-composition of the pipeline and ensures the
historical releases never re-activate their predecessors.

Signed-off-by: Oleg Sidorov <oleg.sidorov@booking.com>
hihilla pushed a commit that referenced this pull request Feb 20, 2020
…tency

Due to a change introduced in #285, shipper strarted re-activating
historical releases due to the way targetStep is resolved. The
aforementioned step changed the composition of the pipeline and caused
historical releases to be re-scheduled. This caused some historical
items to re-activate their capacity and target targets. This change
mainly reverts the re-composition of the pipeline and ensures the
historical releases never re-activate their predecessors.

Signed-off-by: Oleg Sidorov <oleg.sidorov@booking.com>
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants