From d1c32e5a90821fd6135649d1ab424a290ece19ef Mon Sep 17 00:00:00 2001 From: Fabricio Aguiar Date: Thu, 25 Jul 2024 09:48:55 +0100 Subject: [PATCH] Requeue when TLS secret isn't found closes OSPRH-7090 Signed-off-by: Fabricio Aguiar --- modules/certmanager/certificate.go | 16 ++++++++++------ .../test/functional/certmanager_test.go | 4 ++-- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/modules/certmanager/certificate.go b/modules/certmanager/certificate.go index 84430026..d4e89fea 100644 --- a/modules/certmanager/certificate.go +++ b/modules/certmanager/certificate.go @@ -103,7 +103,7 @@ func (c *Certificate) CreateOrPatch( ctx context.Context, h *helper.Helper, owner client.Object, -) (ctrl.Result, error) { +) (ctrl.Result, controllerutil.OperationResult, error) { var err error cert := &certmgrv1.Certificate{ ObjectMeta: metav1.ObjectMeta{ @@ -131,15 +131,15 @@ func (c *Certificate) CreateOrPatch( if err != nil { if k8s_errors.IsNotFound(err) { h.GetLogger().Info(fmt.Sprintf("Certificate %s not found, reconcile in %s", cert.Name, c.timeout)) - return ctrl.Result{RequeueAfter: c.timeout}, nil + return ctrl.Result{RequeueAfter: c.timeout}, op, nil } - return ctrl.Result{}, err + return ctrl.Result{}, op, err } if op != controllerutil.OperationResultNone { h.GetLogger().Info(fmt.Sprintf("Route %s - %s", cert.Name, op)) } - return ctrl.Result{}, nil + return ctrl.Result{}, op, nil } // Delete - delete a certificate. @@ -156,7 +156,7 @@ func (c *Certificate) Delete( return nil } -// EnsureCert - creates a certificate, ensures the sercret has the required key/cert and return the secret +// EnsureCert - creates a certificate, ensures the secret has the required key/cert and return the secret func EnsureCert( ctx context.Context, helper *helper.Helper, @@ -233,7 +233,7 @@ func EnsureCert( ) cert := NewCertificate(certReq, 5) - ctrlResult, err := cert.CreateOrPatch(ctx, helper, owner) + ctrlResult, op, err := cert.CreateOrPatch(ctx, helper, owner) if err != nil { return nil, ctrlResult, err } else if (ctrlResult != ctrl.Result{}) { @@ -243,6 +243,10 @@ func EnsureCert( // get cert secret certSecret, _, err := secret.GetSecret(ctx, helper, certSecretName, namespace) if err != nil { + if k8s_errors.IsNotFound(err) && op == controllerutil.OperationResultCreated { + helper.GetLogger().Info(fmt.Sprintf("Secret %s not found, reconcile in %s", certSecretName, cert.timeout)) + return nil, ctrl.Result{RequeueAfter: cert.timeout}, nil + } return nil, ctrl.Result{}, err } diff --git a/modules/certmanager/test/functional/certmanager_test.go b/modules/certmanager/test/functional/certmanager_test.go index 21bfca1d..3423ec1b 100644 --- a/modules/certmanager/test/functional/certmanager_test.go +++ b/modules/certmanager/test/functional/certmanager_test.go @@ -158,7 +158,7 @@ var _ = Describe("certmanager module", func() { timeout, ) - _, err := c.CreateOrPatch(ctx, h, nil) + _, _, err := c.CreateOrPatch(ctx, h, nil) Expect(err).ShouldNot(HaveOccurred()) cert := th.GetCert(names.CertName) Expect(cert.Spec.CommonName).To(Equal("keystone-public-openstack.apps-crc.testing")) @@ -188,7 +188,7 @@ var _ = Describe("certmanager module", func() { timeout, ) - _, err := c.CreateOrPatch(ctx, h, nil) + _, _, err := c.CreateOrPatch(ctx, h, nil) Expect(err).ShouldNot(HaveOccurred()) cert := th.GetCert(names.CertName) Expect(cert).NotTo(BeNil())