Skip to content

Commit

Permalink
fix: take into account chart version when determine the apply strategy
Browse files Browse the repository at this point in the history
  • Loading branch information
lburgazzoli committed Oct 2, 2024
1 parent aaf689f commit bcb66da
Show file tree
Hide file tree
Showing 5 changed files with 40 additions and 23 deletions.
2 changes: 1 addition & 1 deletion api/operator/v1alpha1/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ require (
github.com/gorilla/mux v1.8.1
github.com/hashicorp/go-cleanhttp v0.5.2
github.com/lburgazzoli/gomega-matchers v0.1.0
github.com/lburgazzoli/k8s-manifests-renderer-helm v0.1.1
github.com/lburgazzoli/k8s-manifests-renderer-helm v0.1.2
github.com/onsi/gomega v1.34.2
github.com/operator-framework/api v0.27.0
github.com/operator-framework/operator-lifecycle-manager v0.22.0
Expand Down
2 changes: 2 additions & 0 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -247,6 +247,8 @@ github.com/lburgazzoli/gomega-matchers v0.1.0 h1:jkW45zWWGz6CP9EaUCKWcWgXiogiuHE
github.com/lburgazzoli/gomega-matchers v0.1.0/go.mod h1:MwRD1wEQrYBrON1pBYI/bwohSd3xeqflZa9nxXeSd9Q=
github.com/lburgazzoli/k8s-manifests-renderer-helm v0.1.1 h1:vFpZ2tLT56bVNCtlzfI9z/FXAiVS1SRRUyPkogFhwlI=
github.com/lburgazzoli/k8s-manifests-renderer-helm v0.1.1/go.mod h1:eqarsYWia91+fzg1Nzhol5rUO3WOEy6Z1acXr+1lCMs=
github.com/lburgazzoli/k8s-manifests-renderer-helm v0.1.2 h1:eedxAOiV6kwzIT594Mz6RCTc0uiyUv/1z6Ai7N0l+M4=
github.com/lburgazzoli/k8s-manifests-renderer-helm v0.1.2/go.mod h1:m3GWnxJgaLSTqc6k3EZZpjdDSIE+HqyjQicjgxn4xAo=
github.com/lib/pq v1.10.9 h1:YXG7RB+JIjhP29X+OtkiDnYaXQwpS4JEWq7dtCCRUEw=
github.com/lib/pq v1.10.9/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
github.com/liggitt/tabwriter v0.0.0-20181228230101-89fcab3d43de h1:9TO3cAIGXtEhnIaL+V+BEER86oLrvS+kWobKpbJuye0=
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,17 @@ func (a *ApplyCRDsAction) Run(ctx context.Context, rc *ReconciliationRequest) er
return fmt.Errorf("cannot load CRDs: %w", err)
}

invalidate := false

versionChanged := false
if rc.Resource.Status.Chart != nil {
versionChanged = rc.Resource.Status.Chart.Version != c.Version() ||
rc.Resource.Status.Chart.Name != c.Name() ||
rc.Resource.Status.Chart.Repo != c.Repo()
}

force := rc.Resource.Generation != rc.Resource.Status.ObservedGeneration || versionChanged

for _, crd := range crds {
resources.Labels(&crd, map[string]string{
helm.ReleaseGeneration: strconv.FormatInt(rc.Resource.Generation, 10),
Expand All @@ -59,14 +70,20 @@ func (a *ApplyCRDsAction) Run(ctx context.Context, rc *ReconciliationRequest) er
helm.ReleaseVersion: c.Version(),
})

err = a.apply(ctx, rc, &crd)
applied, err := a.apply(ctx, rc, &crd, force)
if err != nil {
return err
}

if applied {
invalidate = true
}
}

// invalidate the client so it gets aware of the new CRDs
rc.Client.Invalidate()
if invalidate {
// invalidate the client so it gets aware of the new CRDs
rc.Client.Invalidate()
}

return nil
}
Expand All @@ -75,32 +92,28 @@ func (a *ApplyCRDsAction) Cleanup(_ context.Context, _ *ReconciliationRequest) e
return nil
}

func (a *ApplyCRDsAction) apply(ctx context.Context, rc *ReconciliationRequest, crd *unstructured.Unstructured) error {
func (a *ApplyCRDsAction) apply(ctx context.Context, rc *ReconciliationRequest, crd *unstructured.Unstructured, apply bool) (bool, error) {
dc, err := rc.Client.Dynamic(rc.Resource.Namespace, crd)
if err != nil {
return fmt.Errorf("cannot create dynamic client: %w", err)
return false, fmt.Errorf("cannot create dynamic client: %w", err)
}

apply := rc.Resource.Generation != rc.Resource.Status.ObservedGeneration

_, err = dc.Get(ctx, crd.GetName(), metav1.GetOptions{})
if err != nil && !k8serrors.IsNotFound(err) {
return fmt.Errorf("cannot determine if CRD %s exists: %w", resources.Ref(crd), err)
return false, fmt.Errorf("cannot determine if CRD %s exists: %w", resources.Ref(crd), err)
}

if err != nil && k8serrors.IsNotFound(err) {
if k8serrors.IsNotFound(err) {
apply = true
}

if !apply {
a.l.Info("run",
"apply", "false",
"gen", rc.Resource.Generation,
"ref", resources.Ref(crd),
"generation-changed", rc.Resource.Generation != rc.Resource.Status.ObservedGeneration,
"not-found", k8serrors.IsNotFound(err))
"ref", resources.Ref(crd))

return nil
return false, nil
}

_, err = dc.Apply(ctx, crd.GetName(), crd, metav1.ApplyOptions{
Expand All @@ -109,13 +122,13 @@ func (a *ApplyCRDsAction) apply(ctx context.Context, rc *ReconciliationRequest,
})

if err != nil {
return fmt.Errorf("cannot apply CRD %s: %w", resources.Ref(crd), err)
return false, fmt.Errorf("cannot apply CRD %s: %w", resources.Ref(crd), err)
}

a.l.Info("run",
"apply", "true",
"gen", rc.Resource.Generation,
"ref", resources.Ref(crd))

return nil
return true, nil
}
Original file line number Diff line number Diff line change
Expand Up @@ -63,23 +63,25 @@ func (a *ApplyResourcesAction) Run(ctx context.Context, rc *ReconciliationReques
return istr < jstr
})

installedVersion := ""
versionChanged := false
if rc.Resource.Status.Chart != nil {
installedVersion = rc.Resource.Status.Chart.Version
versionChanged = rc.Resource.Status.Chart.Version != c.Version() ||
rc.Resource.Status.Chart.Name != c.Name() ||
rc.Resource.Status.Chart.Repo != c.Repo()
}

force := rc.Resource.Generation != rc.Resource.Status.ObservedGeneration || c.Version() != installedVersion
force := rc.Resource.Generation != rc.Resource.Status.ObservedGeneration || versionChanged

if force {
rc.Reconciler.Event(
rc.Resource,
corev1.EventTypeNormal,
"RenderFullHelmTemplate",
fmt.Sprintf("Render full Helm template (observedGeneration: %d, generation: %d, installedChartVersion: %s, chartVersion: %s)",
fmt.Sprintf("Render full Helm template (observedGeneration: %d, generation: %d, installedChart: %v, chart: %v)",
rc.Resource.Status.ObservedGeneration,
rc.Resource.Generation,
installedVersion,
c.Version()),
rc.Resource.Status.Chart,
c.Spec()),
)
}

Expand Down

0 comments on commit bcb66da

Please sign in to comment.