From 96ea095a35f92edb2e5069cc308d80516758c749 Mon Sep 17 00:00:00 2001 From: Danil-Grigorev Date: Tue, 3 Sep 2024 10:35:11 +0200 Subject: [PATCH] Pass image overrides to in-memory client Signed-off-by: Danil-Grigorev --- .../controller/manifests_downloader_test.go | 49 +++++++++++++++++++ internal/controller/phases.go | 24 +++++++-- 2 files changed, 69 insertions(+), 4 deletions(-) diff --git a/internal/controller/manifests_downloader_test.go b/internal/controller/manifests_downloader_test.go index f564100b9..4682ead2f 100644 --- a/internal/controller/manifests_downloader_test.go +++ b/internal/controller/manifests_downloader_test.go @@ -22,6 +22,7 @@ import ( . "github.com/onsi/gomega" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + configclient "sigs.k8s.io/cluster-api/cmd/clusterctl/client/config" "sigs.k8s.io/controller-runtime/pkg/client/fake" operatorv1 "sigs.k8s.io/cluster-api-operator/api/v1alpha2" @@ -67,3 +68,51 @@ func TestManifestsDownloader(t *testing.T) { g.Expect(exists).To(BeTrue()) } + +func TestProviderDownloadWithOverrides(t *testing.T) { + g := NewWithT(t) + + ctx := context.Background() + + fakeclient := fake.NewClientBuilder().WithObjects().Build() + + namespace := "test-namespace" + + overridesClient, err := configclient.New(ctx, "") + g.Expect(err).ToNot(HaveOccurred()) + + overridesClient.Variables().Set("images", ` +all: + repository: "myorg.io/local-repo" +`) + + p := &phaseReconciler{ + ctrlClient: fakeclient, + provider: &operatorv1.CoreProvider{ + ObjectMeta: metav1.ObjectMeta{ + Name: "cluster-api", + Namespace: namespace, + }, + Spec: operatorv1.CoreProviderSpec{ + ProviderSpec: operatorv1.ProviderSpec{ + Version: "v1.4.3", + }, + }, + }, + overridesClient: overridesClient, + } + + _, err = p.initializePhaseReconciler(ctx) + g.Expect(err).ToNot(HaveOccurred()) + + _, err = p.downloadManifests(ctx) + g.Expect(err).ToNot(HaveOccurred()) + + _, err = p.load(ctx) + g.Expect(err).ToNot(HaveOccurred()) + + _, err = p.fetch(ctx) + g.Expect(err).ToNot(HaveOccurred()) + + g.Expect(p.components.Images()).To(HaveExactElements([]string{"myorg.io/local-repo/cluster-api-controller:v1.4.3"})) +} diff --git a/internal/controller/phases.go b/internal/controller/phases.go index 633389980..fb8cf0a96 100644 --- a/internal/controller/phases.go +++ b/internal/controller/phases.go @@ -65,6 +65,7 @@ type phaseReconciler struct { options repository.ComponentsOptions providerConfig configclient.Provider configClient configclient.Client + overridesClient configclient.Client components repository.Components clusterctlProvider *clusterctlv1.Provider } @@ -126,18 +127,33 @@ func (p *phaseReconciler) initializePhaseReconciler(ctx context.Context) (reconc initConfig, err := configclient.New(ctx, path) if err != nil { return reconcile.Result{}, err + } else if path != "" { + // Set the image and providers override client + p.overridesClient = initConfig } - providers, err := initConfig.Providers().List() - if err != nil { - return reconcile.Result{}, err + overrideProviders := []configclient.Provider{} + + if p.overridesClient != nil { + providers, err := p.overridesClient.Providers().List() + if err != nil { + return reconcile.Result{}, err + } + + overrideProviders = providers } - reader, err := p.secretReader(ctx, providers...) + reader, err := p.secretReader(ctx, overrideProviders...) if err != nil { return reconcile.Result{}, err } + if p.overridesClient != nil { + if imageOverrides, err := p.overridesClient.Variables().Get("images"); err == nil { + reader.Set("images", imageOverrides) + } + } + // Load provider's secret and config url. p.configClient, err = configclient.New(ctx, "", configclient.InjectReader(reader)) if err != nil {