Skip to content

Commit

Permalink
Preserve ApplicationSet template finalizers (#190)
Browse files Browse the repository at this point in the history
* Initialize destination namespace labels

This fixes the `Label destionation namespace - same as CTI` test and
a possible bug scenario.

Signed-off-by: Alex Misstear <[email protected]>

* Preserve ApplicationSet template finalizers

This allows ApplicationSet admins to customize the finalizers while ensuring
`resources-finalizer.argocd.argoproj.io` is always applied for proper cleanup.

Signed-off-by: Alex Misstear <[email protected]>

---------

Signed-off-by: Alex Misstear <[email protected]>
  • Loading branch information
amisstea authored Apr 25, 2024
1 parent bfcdd6f commit ea9ff44
Show file tree
Hide file tree
Showing 4 changed files with 31 additions and 8 deletions.
15 changes: 12 additions & 3 deletions api/v1alpha1/clustertemplateinstance_utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@ import (
"context"
"encoding/json"

"golang.org/x/exp/slices"

argo "github.com/argoproj/argo-cd/v2/pkg/apis/application/v1alpha1"
"github.com/kubernetes-client/go-base/config/api"
"gopkg.in/yaml.v2"
Expand Down Expand Up @@ -183,9 +185,6 @@ func (i *ClusterTemplateInstance) UpdateApplicationSet(
Template: argo.ApplicationSetTemplate{
ApplicationSetTemplateMeta: argo.ApplicationSetTemplateMeta{
Name: name,
Finalizers: []string{
argo.ResourcesFinalizerName,
},
Labels: map[string]string{
CTINameLabel: i.Name,
CTINamespaceLabel: i.Namespace,
Expand All @@ -195,6 +194,13 @@ func (i *ClusterTemplateInstance) UpdateApplicationSet(
},
}

// To guarantee App cleanup, add the resource finalizer to the generator's template if it's not already defined in the AppSet's template.
// Preserve any other finalizers the AppSet author may have included.
found := slices.Contains(appSet.Spec.Template.Finalizers, argo.ResourcesFinalizerName)
if !found {
gen.List.Template.ApplicationSetTemplateMeta.Finalizers = append(appSet.Spec.Template.Finalizers, argo.ResourcesFinalizerName)
}

if appSet.Spec.Template.Spec.Source.Chart != "" {
params, err := i.GetHelmParameters(appSet, isDay2)
if err != nil {
Expand Down Expand Up @@ -237,6 +243,9 @@ func (i *ClusterTemplateInstance) labelDestionationNamespace(ctx context.Context
}

if l, lOk := ns.Labels["argocd.argoproj.io/managed-by"]; !lOk || l != argoCDNamespace {
if ns.Labels == nil {
ns.Labels = map[string]string{}
}
ns.Labels["argocd.argoproj.io/managed-by"] = argoCDNamespace
if err := k8sClient.Update(ctx, ns); err != nil {
return err
Expand Down
14 changes: 13 additions & 1 deletion api/v1alpha1/clustertemplateinstance_utils_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -354,7 +354,13 @@ var _ = Describe("ClusterTemplateInstance utils", func() {
Name: "foo",
Namespace: "cluster-aas-operator",
},
Spec: argo.ApplicationSetSpec{},
Spec: argo.ApplicationSetSpec{
Template: argo.ApplicationSetTemplate{
ApplicationSetTemplateMeta: argo.ApplicationSetTemplateMeta{
Finalizers: []string{"fooFinalizer"},
},
},
},
}

client := fake.NewFakeClientWithScheme(scheme.Scheme, appset)
Expand All @@ -367,6 +373,8 @@ var _ = Describe("ClusterTemplateInstance utils", func() {

Expect(len(a.Items[0].Spec.Generators)).To(Equal(1))
Expect(len(a.Items[0].Spec.Generators[0].List.Elements)).To(Equal(1))
Expect(len(a.Items[0].Spec.Generators[0].List.Template.Finalizers)).To(Equal(2))
Expect(a.Items[0].Spec.Generators[0].List.Template.Finalizers).To(Equal([]string{"fooFinalizer", argo.ResourcesFinalizerName}))

s, err := a.Items[0].Spec.Generators[0].List.Elements[0].MarshalJSON()
Expect(err).ToNot(HaveOccurred())
Expand Down Expand Up @@ -418,6 +426,9 @@ var _ = Describe("ClusterTemplateInstance utils", func() {
Spec: argo.ApplicationSetSpec{
Generators: []argo.ApplicationSetGenerator{{}},
Template: argo.ApplicationSetTemplate{
ApplicationSetTemplateMeta: argo.ApplicationSetTemplateMeta{
Finalizers: []string{argo.ResourcesFinalizerName},
},
Spec: argo.ApplicationSpec{
Source: argo.ApplicationSource{},
},
Expand All @@ -435,6 +446,7 @@ var _ = Describe("ClusterTemplateInstance utils", func() {
//Expect(appsets.Items[0].Spec.Generators[0].String()).To(Equal(""))
Expect(len(appsets.Items[0].Spec.Generators)).To(Equal(2))
Expect(len(appsets.Items[0].Spec.Generators[1].List.Elements)).To(Equal(1))
Expect(len(appsets.Items[0].Spec.Generators[1].List.Template.Finalizers)).To(Equal(0))

data, err = appsets.Items[0].Spec.Generators[1].List.Elements[0].MarshalJSON()
Expect(err).ShouldNot(HaveOccurred())
Expand Down
4 changes: 2 additions & 2 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ require (
github.com/spf13/pflag v1.0.5
github.com/stolostron/backplane-operator v0.0.0-20220727154840-1f60baf1fb98
github.com/stolostron/klusterlet-addon-controller v0.0.0-20230220122621-1dc02f9d616c
golang.org/x/exp v0.0.0-20240416160154-fe59bbe5cc7f
gopkg.in/yaml.v2 v2.4.0
gopkg.in/yaml.v3 v3.0.1
helm.sh/helm/v3 v3.9.4
Expand Down Expand Up @@ -239,11 +240,10 @@ require (
go.uber.org/multierr v1.8.0 // indirect
go.uber.org/zap v1.21.0 // indirect
golang.org/x/crypto v0.3.0 // indirect
golang.org/x/exp v0.0.0-20210901193431-a062eea981d2 // indirect
golang.org/x/image v0.0.0-20191206065243-da761ea9ff43 // indirect
golang.org/x/net v0.4.0 // indirect
golang.org/x/oauth2 v0.0.0-20220722155238-128564f6959c // indirect
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4 // indirect
golang.org/x/sync v0.7.0 // indirect
golang.org/x/sys v0.3.0 // indirect
golang.org/x/term v0.3.0 // indirect
golang.org/x/text v0.5.0 // indirect
Expand Down
6 changes: 4 additions & 2 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -1262,8 +1262,9 @@ golang.org/x/exp v0.0.0-20200119233911-0405dc783f0a/go.mod h1:2RIsYlXP63K8oxa1u0
golang.org/x/exp v0.0.0-20200207192155-f17229e696bd/go.mod h1:J/WKrq2StrnmMY6+EHIKF9dgMWnmCNThgcyBT1FY9mM=
golang.org/x/exp v0.0.0-20200224162631-6cc2880d07d6/go.mod h1:3jZMyOhIsHpP37uCMkUooju7aAi5cS1Q23tOzKc+0MU=
golang.org/x/exp v0.0.0-20210220032938-85be41e4509f/go.mod h1:I6l2HNBLBZEcrOoCpyKLdY2lHoRZ8lI4x60KMCQDft4=
golang.org/x/exp v0.0.0-20210901193431-a062eea981d2 h1:Or4Ra3AAlhUlNn8WmIzw2Yq2vUHSkrP6E2e/FIESpF8=
golang.org/x/exp v0.0.0-20210901193431-a062eea981d2/go.mod h1:a3o/VtDNHN+dCVLEpzjjUHOzR+Ln3DHX056ZPzoZGGA=
golang.org/x/exp v0.0.0-20240416160154-fe59bbe5cc7f h1:99ci1mjWVBWwJiEKYY6jWa4d2nTQVIEhZIptnrVb1XY=
golang.org/x/exp v0.0.0-20240416160154-fe59bbe5cc7f/go.mod h1:/lliqkxwWAhPjf5oSOIJup2XcqJaw8RGS6k3TGEc7GI=
golang.org/x/image v0.0.0-20180708004352-c73c2afc3b81/go.mod h1:ux5Hcp/YLpHSI86hEcLt0YII63i6oz57MZXIpbrjZUs=
golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js=
golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
Expand Down Expand Up @@ -1403,8 +1404,9 @@ golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJ
golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20220601150217-0de741cfad7f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4 h1:uVc8UZUe6tr40fFVnUP5Oj+veunVezqYl9z7DYw9xzw=
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.7.0 h1:YsImfSBoP9QPYL0xyKJPq0gcaJdG3rInoqxTWbfQu9M=
golang.org/x/sync v0.7.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20180903190138-2b024373dcd9/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
Expand Down

0 comments on commit ea9ff44

Please sign in to comment.