From 133a3da390b8f0ebcea4754b2c5ddd1b94fa6d7f Mon Sep 17 00:00:00 2001 From: Merijn Wijngaard Date: Tue, 12 Mar 2024 16:22:46 +0100 Subject: [PATCH] Pass AppNamespace to UpdateSpec api call, to support applications in other namespaces than argocd itself (when using the argocd api). Signed-off-by: Merijn Wijngaard --- pkg/argocd/update.go | 5 +++-- pkg/argocd/update_test.go | 12 +++++++++--- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/pkg/argocd/update.go b/pkg/argocd/update.go index 855bbdd0..fc3a0c24 100644 --- a/pkg/argocd/update.go +++ b/pkg/argocd/update.go @@ -613,8 +613,9 @@ func commitChanges(app *v1alpha1.Application, wbc *WriteBackConfig, changeList [ switch wbc.Method { case WriteBackApplication: _, err := wbc.ArgoClient.UpdateSpec(context.TODO(), &application.ApplicationUpdateSpecRequest{ - Name: &app.Name, - Spec: &app.Spec, + Name: &app.Name, + AppNamespace: &app.Namespace, + Spec: &app.Spec, }) if err != nil { return err diff --git a/pkg/argocd/update_test.go b/pkg/argocd/update_test.go index 1d1246fa..d5ae9e1c 100644 --- a/pkg/argocd/update_test.go +++ b/pkg/argocd/update_test.go @@ -21,6 +21,7 @@ import ( "github.com/argoproj-labs/argocd-image-updater/test/fake" "github.com/argoproj-labs/argocd-image-updater/test/fixture" + "github.com/argoproj/argo-cd/v2/pkg/apiclient/application" "github.com/argoproj/argo-cd/v2/pkg/apis/application/v1alpha1" argogit "github.com/argoproj/argo-cd/v2/util/git" "github.com/distribution/distribution/v3/manifest/schema1" //nolint:staticcheck @@ -103,9 +104,6 @@ func Test_UpdateApplication(t *testing.T) { return ®Mock, nil } - argoClient := argomock.ArgoCD{} - argoClient.On("UpdateSpec", mock.Anything, mock.Anything).Return(nil, nil) - kubeClient := kube.KubernetesClient{ Clientset: fake.NewFakeKubeClient(), } @@ -137,6 +135,14 @@ func Test_UpdateApplication(t *testing.T) { image.NewFromIdentifier("jannfis/foobar:~1.0.0"), }, } + + argoClient := argomock.ArgoCD{} + argoClient.On("UpdateSpec", mock.Anything, &application.ApplicationUpdateSpecRequest{ + Name: &appImages.Application.Name, + AppNamespace: &appImages.Application.Namespace, + Spec: &appImages.Application.Spec, + }).Return(nil, nil) + res := UpdateApplication(&UpdateConfiguration{ NewRegFN: mockClientFn, ArgoClient: &argoClient,