Skip to content

Commit

Permalink
Preserve ApplicationSet template finalizers
Browse files Browse the repository at this point in the history
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]>
  • Loading branch information
amisstea committed Apr 24, 2024
1 parent 8b6fd6a commit 4244609
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 6 deletions.
12 changes: 9 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
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 @@ -239,11 +239,11 @@ 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/exp v0.0.0-20240416160154-fe59bbe5cc7f // 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
4 changes: 4 additions & 0 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -1264,6 +1264,8 @@ golang.org/x/exp v0.0.0-20200224162631-6cc2880d07d6/go.mod h1:3jZMyOhIsHpP37uCMk
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 @@ -1405,6 +1407,8 @@ golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJ
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 4244609

Please sign in to comment.