From 6e2b49661b0dcad3f9e3ab75c0fd2fa269fe0113 Mon Sep 17 00:00:00 2001 From: Maskym Vavilov Date: Wed, 27 Mar 2024 12:28:41 +0000 Subject: [PATCH] GH-36 dns record lifecycle --- .../conditions => api/v1alpha1}/conditions.go | 2 +- api/v1alpha1/dnsrecord_types.go | 13 +++ api/v1alpha1/zz_generated.deepcopy.go | 2 + .../dns-operator.clusterserviceversion.yaml | 2 +- bundle/manifests/kuadrant.io_dnsrecords.yaml | 20 ++++ cmd/main.go | 17 ++- config/crd/bases/kuadrant.io_dnsrecords.yaml | 20 ++++ internal/controller/dnsrecord_controller.go | 109 ++++++++++++------ .../controller/dnsrecord_controller_test.go | 5 +- internal/controller/managedzone_controller.go | 7 +- test/e2e/single_cluster_record_test.go | 9 +- 11 files changed, 153 insertions(+), 53 deletions(-) rename {internal/common/conditions => api/v1alpha1}/conditions.go (84%) diff --git a/internal/common/conditions/conditions.go b/api/v1alpha1/conditions.go similarity index 84% rename from internal/common/conditions/conditions.go rename to api/v1alpha1/conditions.go index 2a0b11d2..db246752 100644 --- a/internal/common/conditions/conditions.go +++ b/api/v1alpha1/conditions.go @@ -1,4 +1,4 @@ -package conditions +package v1alpha1 type ConditionType string type ConditionReason string diff --git a/api/v1alpha1/dnsrecord_types.go b/api/v1alpha1/dnsrecord_types.go index 63228984..b5c451d8 100644 --- a/api/v1alpha1/dnsrecord_types.go +++ b/api/v1alpha1/dnsrecord_types.go @@ -63,6 +63,19 @@ type DNSRecordStatus struct { // +optional ObservedGeneration int64 `json:"observedGeneration,omitempty"` + // QueuedAt is a time when DNS record was received for the reconciliation + QueuedAt metav1.Time `json:"queuedAt,omitempty"` + + // QueuedFor is a time when we expect a DNS record to be reconciled again + QueuedFor metav1.Time `json:"queuedFor,omitempty"` + + // ValidFor indicates duration since the last reconciliation we consider data in the record to be valid + ValidFor string `json:"validFor,omitempty"` + + // WriteCounter represent a number of consecutive write attempts on the same generation of the record. + // It is being reset to 0 when the generation changes or there are no changes to write. + WriteCounter int64 `json:"writeCounter,omitempty"` + // endpoints are the last endpoints that were successfully published by the provider // // Provides a simple mechanism to store the current provider records in order to diff --git a/api/v1alpha1/zz_generated.deepcopy.go b/api/v1alpha1/zz_generated.deepcopy.go index a9642445..463a1dff 100644 --- a/api/v1alpha1/zz_generated.deepcopy.go +++ b/api/v1alpha1/zz_generated.deepcopy.go @@ -137,6 +137,8 @@ func (in *DNSRecordStatus) DeepCopyInto(out *DNSRecordStatus) { (*in)[i].DeepCopyInto(&(*out)[i]) } } + in.QueuedAt.DeepCopyInto(&out.QueuedAt) + in.QueuedFor.DeepCopyInto(&out.QueuedFor) if in.Endpoints != nil { in, out := &in.Endpoints, &out.Endpoints *out = make([]*endpoint.Endpoint, len(*in)) diff --git a/bundle/manifests/dns-operator.clusterserviceversion.yaml b/bundle/manifests/dns-operator.clusterserviceversion.yaml index 8730f04f..58c6cdbc 100644 --- a/bundle/manifests/dns-operator.clusterserviceversion.yaml +++ b/bundle/manifests/dns-operator.clusterserviceversion.yaml @@ -56,7 +56,7 @@ metadata: capabilities: Basic Install categories: Integration & Delivery containerImage: quay.io/kuadrant/dns-operator:latest - createdAt: "2024-03-15T11:01:46Z" + createdAt: "2024-04-03T14:02:57Z" description: A Kubernetes Operator to manage the lifecycle of DNS resources operators.operatorframework.io/builder: operator-sdk-v1.33.0 operators.operatorframework.io/project_layout: go.kubebuilder.io/v4 diff --git a/bundle/manifests/kuadrant.io_dnsrecords.yaml b/bundle/manifests/kuadrant.io_dnsrecords.yaml index 52b3e807..f8f46700 100644 --- a/bundle/manifests/kuadrant.io_dnsrecords.yaml +++ b/bundle/manifests/kuadrant.io_dnsrecords.yaml @@ -242,6 +242,26 @@ spec: it needs to retry the update for that specific zone. format: int64 type: integer + queuedAt: + description: QueuedAt is a time when DNS record was received for the + reconciliation + format: date-time + type: string + queuedFor: + description: QueuedFor is a time when we expect a DNS record to be + reconciled again + format: date-time + type: string + validFor: + description: ValidFor indicates duration since the last reconciliation + we consider data in the record to be valid + type: string + writeCounter: + description: WriteCounter represent a number of consecutive write + attempts on the same generation of the record. It is being reset + to 0 when the generation changes or there are no changes to write. + format: int64 + type: integer type: object type: object served: true diff --git a/cmd/main.go b/cmd/main.go index 208ed3bf..c044baaf 100644 --- a/cmd/main.go +++ b/cmd/main.go @@ -19,6 +19,7 @@ package main import ( "flag" "os" + "time" "k8s.io/apimachinery/pkg/runtime" utilruntime "k8s.io/apimachinery/pkg/util/runtime" @@ -43,6 +44,11 @@ var ( setupLog = ctrl.Log.WithName("setup") ) +const ( + RequeueDuration = time.Minute * 15 + ValidityDuration = time.Minute * 14 +) + func init() { utilruntime.Must(clientgoscheme.AddToScheme(scheme)) @@ -54,11 +60,20 @@ func main() { var metricsAddr string var enableLeaderElection bool var probeAddr string + var requeueTime time.Duration + var validFor time.Duration + // TODO use duration type vars flag.StringVar(&metricsAddr, "metrics-bind-address", ":8080", "The address the metric endpoint binds to.") flag.StringVar(&probeAddr, "health-probe-bind-address", ":8081", "The address the probe endpoint binds to.") flag.BoolVar(&enableLeaderElection, "leader-elect", false, "Enable leader election for controller manager. "+ "Enabling this will ensure there is only one active controller manager.") + flag.DurationVar(&requeueTime, "requeue-time", RequeueDuration, + "Duration for the validation reconciliation loop. "+ + "Controls how ofter record is reconciled") + flag.DurationVar(&validFor, "valid-for", ValidityDuration, + "Duration when the record is considered to hold valid information"+ + "Controls if we commit to the full reconcile loop") opts := zap.Options{ Development: true, } @@ -94,7 +109,7 @@ func main() { Client: mgr.GetClient(), Scheme: mgr.GetScheme(), ProviderFactory: providerFactory, - }).SetupWithManager(mgr); err != nil { + }).SetupWithManager(mgr, requeueTime, validFor); err != nil { setupLog.Error(err, "unable to create controller", "controller", "DNSRecord") os.Exit(1) } diff --git a/config/crd/bases/kuadrant.io_dnsrecords.yaml b/config/crd/bases/kuadrant.io_dnsrecords.yaml index 84a0a083..e510d0e4 100644 --- a/config/crd/bases/kuadrant.io_dnsrecords.yaml +++ b/config/crd/bases/kuadrant.io_dnsrecords.yaml @@ -242,6 +242,26 @@ spec: it needs to retry the update for that specific zone. format: int64 type: integer + queuedAt: + description: QueuedAt is a time when DNS record was received for the + reconciliation + format: date-time + type: string + queuedFor: + description: QueuedFor is a time when we expect a DNS record to be + reconciled again + format: date-time + type: string + validFor: + description: ValidFor indicates duration since the last reconciliation + we consider data in the record to be valid + type: string + writeCounter: + description: WriteCounter represent a number of consecutive write + attempts on the same generation of the record. It is being reset + to 0 when the generation changes or there are no changes to write. + format: int64 + type: integer type: object type: object served: true diff --git a/internal/controller/dnsrecord_controller.go b/internal/controller/dnsrecord_controller.go index edc00af6..9776d2c2 100644 --- a/internal/controller/dnsrecord_controller.go +++ b/internal/controller/dnsrecord_controller.go @@ -18,8 +18,10 @@ package controller import ( "context" + "errors" "fmt" "strings" + "time" "k8s.io/apimachinery/pkg/api/equality" apierrors "k8s.io/apimachinery/pkg/api/errors" @@ -37,7 +39,6 @@ import ( externaldnsprovider "sigs.k8s.io/external-dns/provider" "github.com/kuadrant/dns-operator/api/v1alpha1" - "github.com/kuadrant/dns-operator/internal/common/conditions" "github.com/kuadrant/dns-operator/internal/provider" ) @@ -45,7 +46,13 @@ const ( DNSRecordFinalizer = "kuadrant.io/dns-record" ) -var Clock clock.Clock = clock.RealClock{} +var ( + defaultRequeueTime time.Duration + validationRequeueTime = time.Second * 5 + validFor time.Duration + reconcileStart = metav1.Time{} + Clock clock.Clock = clock.RealClock{} +) // DNSRecordReconciler reconciles a DNSRecord object type DNSRecordReconciler struct { @@ -61,19 +68,21 @@ type DNSRecordReconciler struct { func (r *DNSRecordReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { logger := log.FromContext(ctx) + reconcileStart = metav1.Now() previous := &v1alpha1.DNSRecord{} err := r.Client.Get(ctx, client.ObjectKey{Namespace: req.Namespace, Name: req.Name}, previous) if err != nil { - if err := client.IgnoreNotFound(err); err == nil { + if err = client.IgnoreNotFound(err); err == nil { return ctrl.Result{}, nil } else { return ctrl.Result{}, err } } dnsRecord := previous.DeepCopy() + dnsRecord.Status.QueuedAt = reconcileStart if dnsRecord.DeletionTimestamp != nil && !dnsRecord.DeletionTimestamp.IsZero() { - if err := r.deleteRecord(ctx, dnsRecord); err != nil { + if err = r.deleteRecord(ctx, dnsRecord); err != nil { logger.Error(err, "Failed to delete DNSRecord") return ctrl.Result{}, err } @@ -89,44 +98,46 @@ func (r *DNSRecordReconciler) Reconcile(ctx context.Context, req ctrl.Request) ( } if !controllerutil.ContainsFinalizer(dnsRecord, DNSRecordFinalizer) { + dnsRecord.Status.QueuedFor = metav1.NewTime(reconcileStart.Add(validationRequeueTime)) logger.Info("Adding Finalizer", "name", DNSRecordFinalizer) controllerutil.AddFinalizer(dnsRecord, DNSRecordFinalizer) err = r.Update(ctx, dnsRecord) if err != nil { return ctrl.Result{}, err } - return ctrl.Result{Requeue: true}, nil + return ctrl.Result{RequeueAfter: validationRequeueTime}, nil } var reason, message string - status := metav1.ConditionTrue - reason = "ProviderSuccess" - message = "Provider ensured the dns record" err = dnsRecord.Validate() if err != nil { - status = metav1.ConditionFalse reason = "ValidationError" message = fmt.Sprintf("validation of DNSRecord failed: %v", err) - setDNSRecordCondition(dnsRecord, string(conditions.ConditionTypeReady), status, reason, message) - return r.updateStatus(ctx, previous, dnsRecord) + setDNSRecordCondition(dnsRecord, string(v1alpha1.ConditionTypeReady), metav1.ConditionFalse, reason, message) + return r.updateStatus(ctx, previous, dnsRecord, "0s") } + // Publish the record - err = r.publishRecord(ctx, dnsRecord) + requeueAfter, err := r.publishRecord(ctx, dnsRecord) if err != nil { - status = metav1.ConditionFalse reason = "ProviderError" message = fmt.Sprintf("The DNS provider failed to ensure the record: %v", provider.SanitizeError(err)) - setDNSRecordCondition(dnsRecord, string(conditions.ConditionTypeReady), status, reason, message) - return r.updateStatus(ctx, previous, dnsRecord) + setDNSRecordCondition(dnsRecord, string(v1alpha1.ConditionTypeReady), metav1.ConditionFalse, reason, message) + return r.updateStatus(ctx, previous, dnsRecord, "0s") } // success - setDNSRecordCondition(dnsRecord, string(conditions.ConditionTypeReady), status, reason, message) dnsRecord.Status.ObservedGeneration = dnsRecord.Generation dnsRecord.Status.Endpoints = dnsRecord.Spec.Endpoints - return r.updateStatus(ctx, previous, dnsRecord) + return r.updateStatus(ctx, previous, dnsRecord, requeueAfter) } -func (r *DNSRecordReconciler) updateStatus(ctx context.Context, previous, current *v1alpha1.DNSRecord) (reconcile.Result, error) { +func (r *DNSRecordReconciler) updateStatus(ctx context.Context, previous, current *v1alpha1.DNSRecord, requeueAfter string) (reconcile.Result, error) { + requeueDuration, err := time.ParseDuration(requeueAfter) + if err != nil { + return ctrl.Result{}, errors.New("error parsing duration while setting requeue time") + } + current.Status.QueuedFor = metav1.NewTime(reconcileStart.Add(requeueDuration)) + if !equality.Semantic.DeepEqual(previous.Status, current.Status) { updateError := r.Status().Update(ctx, current) if apierrors.IsConflict(updateError) { @@ -134,11 +145,14 @@ func (r *DNSRecordReconciler) updateStatus(ctx context.Context, previous, curren } return ctrl.Result{}, updateError } - return ctrl.Result{}, nil + return ctrl.Result{RequeueAfter: requeueDuration}, nil } // SetupWithManager sets up the controller with the Manager. -func (r *DNSRecordReconciler) SetupWithManager(mgr ctrl.Manager) error { +func (r *DNSRecordReconciler) SetupWithManager(mgr ctrl.Manager, requeueIn, valid time.Duration) error { + defaultRequeueTime = requeueIn + validFor = valid + return ctrl.NewControllerManagedBy(mgr). For(&v1alpha1.DNSRecord{}). Complete(r) @@ -166,7 +180,7 @@ func (r *DNSRecordReconciler) deleteRecord(ctx context.Context, dnsRecord *v1alp return fmt.Errorf("the managed zone is not in a ready state : %s", managedZone.Name) } - err = r.applyChanges(ctx, dnsRecord, managedZone, true) + _, err = r.applyChanges(ctx, dnsRecord, managedZone, true) if err != nil { if strings.Contains(err.Error(), "was not found") || strings.Contains(err.Error(), "notFound") { logger.Info("Record not found in managed zone, continuing", "dnsRecord", dnsRecord.Name, "managedZone", managedZone.Name) @@ -184,7 +198,7 @@ func (r *DNSRecordReconciler) deleteRecord(ctx context.Context, dnsRecord *v1alp // publishRecord publishes record(s) to the DNSPRovider(i.e. route53) configured by the ManagedZone assigned to this // DNSRecord (dnsRecord.Status.ParentManagedZone). -func (r *DNSRecordReconciler) publishRecord(ctx context.Context, dnsRecord *v1alpha1.DNSRecord) error { +func (r *DNSRecordReconciler) publishRecord(ctx context.Context, dnsRecord *v1alpha1.DNSRecord) (string, error) { logger := log.FromContext(ctx) managedZone := &v1alpha1.ManagedZone{ ObjectMeta: metav1.ObjectMeta{ @@ -194,26 +208,35 @@ func (r *DNSRecordReconciler) publishRecord(ctx context.Context, dnsRecord *v1al } err := r.Get(ctx, client.ObjectKeyFromObject(managedZone), managedZone, &client.GetOptions{}) if err != nil { - return err + return "0s", err } managedZoneReady := meta.IsStatusConditionTrue(managedZone.Status.Conditions, "Ready") if !managedZoneReady { - return fmt.Errorf("the managed zone is not in a ready state : %s", managedZone.Name) + return "0s", fmt.Errorf("the managed zone is not in a ready state : %s", managedZone.Name) } - if dnsRecord.Generation == dnsRecord.Status.ObservedGeneration { + // cut off here for the short reconcile loop + expiryTime := metav1.NewTime(dnsRecord.Status.QueuedAt.Add(validFor)) + if !generationChanged(dnsRecord) && reconcileStart.Before(&expiryTime) { logger.V(3).Info("Skipping managed zone to which the DNS dnsRecord is already published", "dnsRecord", dnsRecord.Name, "managedZone", managedZone.Name) - return nil + return validFor.String(), nil + } + if generationChanged(dnsRecord) { + dnsRecord.Status.WriteCounter = 0 } - err = r.applyChanges(ctx, dnsRecord, managedZone, false) + requeueAfter, err := r.applyChanges(ctx, dnsRecord, managedZone, false) if err != nil { - return err + return "0s", err } logger.Info("Published DNSRecord to manage zone", "dnsRecord", dnsRecord.Name, "managedZone", managedZone.Name) - return nil + return requeueAfter, nil +} + +func generationChanged(record *v1alpha1.DNSRecord) bool { + return record.Generation != record.Status.ObservedGeneration } // setDNSRecordCondition adds or updates a given condition in the DNSRecord status.. @@ -228,7 +251,7 @@ func setDNSRecordCondition(dnsRecord *v1alpha1.DNSRecord, conditionType string, meta.SetStatusCondition(&dnsRecord.Status.Conditions, cond) } -func (r *DNSRecordReconciler) applyChanges(ctx context.Context, dnsRecord *v1alpha1.DNSRecord, managedZone *v1alpha1.ManagedZone, isDelete bool) error { +func (r *DNSRecordReconciler) applyChanges(ctx context.Context, dnsRecord *v1alpha1.DNSRecord, managedZone *v1alpha1.ManagedZone, isDelete bool) (string, error) { logger := log.FromContext(ctx) filterDomain, _ := strings.CutPrefix(managedZone.Spec.DomainName, v1alpha1.WildcardPrefix) if dnsRecord.Spec.RootHost != nil { @@ -244,7 +267,7 @@ func (r *DNSRecordReconciler) applyChanges(ctx context.Context, dnsRecord *v1alp logger.V(3).Info("applyChanges", "zone", managedZone.Spec.DomainName, "rootDomainFilter", rootDomainFilter, "providerConfig", providerConfig) dnsProvider, err := r.ProviderFactory.ProviderFor(ctx, managedZone, providerConfig) if err != nil { - return err + return "0s", err } managedDNSRecordTypes := []string{externaldnsendpoint.RecordTypeA, externaldnsendpoint.RecordTypeAAAA, externaldnsendpoint.RecordTypeCNAME} @@ -252,13 +275,13 @@ func (r *DNSRecordReconciler) applyChanges(ctx context.Context, dnsRecord *v1alp registry, err := dnsRecord.GetRegistry(dnsProvider, managedDNSRecordTypes, excludeDNSRecordTypes) if err != nil { - return err + return "0s", err } policyID := "sync" policy, exists := externaldnsplan.Policies[policyID] if !exists { - return fmt.Errorf("unknown policy: %s", policyID) + return "0s", fmt.Errorf("unknown policy: %s", policyID) } //If we are deleting set the expected endpoints to an empty array @@ -269,19 +292,19 @@ func (r *DNSRecordReconciler) applyChanges(ctx context.Context, dnsRecord *v1alp //zoneEndpoints = Records in the current dns provider zone zoneEndpoints, err := registry.Records(ctx) if err != nil { - return err + return "0s", err } //specEndpoints = Records that this DNSRecord expects to exist specEndpoints, err := registry.AdjustEndpoints(dnsRecord.Spec.Endpoints) if err != nil { - return fmt.Errorf("adjusting specEndpoints: %w", err) + return "0s", fmt.Errorf("adjusting specEndpoints: %w", err) } //statusEndpoints = Records that were created/updated by this DNSRecord last statusEndpoints, err := registry.AdjustEndpoints(dnsRecord.Status.Endpoints) if err != nil { - return fmt.Errorf("adjusting statusEndpoints: %w", err) + return "0s", fmt.Errorf("adjusting statusEndpoints: %w", err) } //Note: All endpoint lists should be in the same provider specific format at this point @@ -302,15 +325,25 @@ func (r *DNSRecordReconciler) applyChanges(ctx context.Context, dnsRecord *v1alp plan = plan.Calculate() + dnsRecord.Status.ValidFor = defaultRequeueTime.String() if plan.Changes.HasChanges() { + // generation has not changed but there are changes. + // implies that they were overridden - bump write counter + if !generationChanged(dnsRecord) { + dnsRecord.Status.WriteCounter++ + } + dnsRecord.Status.ValidFor = validationRequeueTime.String() + setDNSRecordCondition(dnsRecord, string(v1alpha1.ConditionTypeReady), metav1.ConditionFalse, "Awaiting validation", "Awaiting validation") logger.Info("Applying changes") err = registry.ApplyChanges(ctx, plan.Changes) if err != nil { - return err + return dnsRecord.Status.ValidFor, err } } else { logger.Info("All records are already up to date") + dnsRecord.Status.WriteCounter = 0 + setDNSRecordCondition(dnsRecord, string(v1alpha1.ConditionTypeReady), metav1.ConditionTrue, "ProviderSuccess", "Provider ensured the dns record") } - return nil + return dnsRecord.Status.ValidFor, nil } diff --git a/internal/controller/dnsrecord_controller_test.go b/internal/controller/dnsrecord_controller_test.go index df6c0e30..2505db25 100644 --- a/internal/controller/dnsrecord_controller_test.go +++ b/internal/controller/dnsrecord_controller_test.go @@ -31,7 +31,6 @@ import ( externaldnsendpoint "sigs.k8s.io/external-dns/endpoint" "github.com/kuadrant/dns-operator/api/v1alpha1" - "github.com/kuadrant/dns-operator/internal/common/conditions" ) var _ = Describe("DNSRecordReconciler", func() { @@ -89,7 +88,7 @@ var _ = Describe("DNSRecordReconciler", func() { g.Expect(err).NotTo(HaveOccurred()) g.Expect(dnsRecord.Status.Conditions).To( ContainElement(MatchFields(IgnoreExtras, Fields{ - "Type": Equal(string(conditions.ConditionTypeReady)), + "Type": Equal(string(v1alpha1.ConditionTypeReady)), "Status": Equal(metav1.ConditionTrue), "Reason": Equal("ProviderSuccess"), "Message": Equal("Provider ensured the dns record"), @@ -108,7 +107,7 @@ var _ = Describe("DNSRecordReconciler", func() { g.Expect(err).NotTo(HaveOccurred()) g.Expect(dnsRecord.Status.Conditions).To( ContainElement(MatchFields(IgnoreExtras, Fields{ - "Type": Equal(string(conditions.ConditionTypeReady)), + "Type": Equal(string(v1alpha1.ConditionTypeReady)), "Status": Equal(metav1.ConditionTrue), "Reason": Equal("ProviderSuccess"), "Message": Equal("Provider ensured the dns record"), diff --git a/internal/controller/managedzone_controller.go b/internal/controller/managedzone_controller.go index 673c18f3..f0ec0dfe 100644 --- a/internal/controller/managedzone_controller.go +++ b/internal/controller/managedzone_controller.go @@ -32,7 +32,6 @@ import ( externaldns "sigs.k8s.io/external-dns/endpoint" "github.com/kuadrant/dns-operator/api/v1alpha1" - "github.com/kuadrant/dns-operator/internal/common/conditions" "github.com/kuadrant/dns-operator/internal/provider" ) @@ -144,7 +143,7 @@ func (r *ManagedZoneReconciler) Reconcile(ctx context.Context, req ctrl.Request) } managedZone.Status.ObservedGeneration = managedZone.Generation - setManagedZoneCondition(managedZone, string(conditions.ConditionTypeReady), status, reason, message) + setManagedZoneCondition(managedZone, string(v1alpha1.ConditionTypeReady), status, reason, message) err = r.Status().Update(ctx, managedZone) if err != nil { return ctrl.Result{}, err @@ -192,7 +191,7 @@ func (r *ManagedZoneReconciler) deleteManagedZone(ctx context.Context, managedZo reason = "ProviderError" message = fmt.Sprintf("The DNS provider creation failed: %v", err) managedZone.Status.ObservedGeneration = managedZone.Generation - setManagedZoneCondition(managedZone, string(conditions.ConditionTypeReady), status, reason, message) + setManagedZoneCondition(managedZone, string(v1alpha1.ConditionTypeReady), status, reason, message) return err } err = dnsProvider.DeleteManagedZone(managedZone) @@ -336,7 +335,7 @@ func (r *ManagedZoneReconciler) parentZoneNSRecordReady(ctx context.Context, man } } - nsRecordReady := meta.IsStatusConditionTrue(nsRecord.Status.Conditions, string(conditions.ConditionTypeReady)) + nsRecordReady := meta.IsStatusConditionTrue(nsRecord.Status.Conditions, string(v1alpha1.ConditionTypeReady)) if !nsRecordReady { return fmt.Errorf("the ns record is not in a ready state : %s", nsRecord.Name) } diff --git a/test/e2e/single_cluster_record_test.go b/test/e2e/single_cluster_record_test.go index 9506ad3b..5d3cdbca 100644 --- a/test/e2e/single_cluster_record_test.go +++ b/test/e2e/single_cluster_record_test.go @@ -17,7 +17,6 @@ import ( externaldnsendpoint "sigs.k8s.io/external-dns/endpoint" "github.com/kuadrant/dns-operator/api/v1alpha1" - "github.com/kuadrant/dns-operator/internal/common/conditions" ) var _ = Describe("Single Cluster Record Test", func() { @@ -86,7 +85,7 @@ var _ = Describe("Single Cluster Record Test", func() { g.Expect(err).NotTo(HaveOccurred()) g.Expect(dnsRecord.Status.Conditions).To( ContainElement(MatchFields(IgnoreExtras, Fields{ - "Type": Equal(string(conditions.ConditionTypeReady)), + "Type": Equal(string(v1alpha1.ConditionTypeReady)), "Status": Equal(metav1.ConditionTrue), })), ) @@ -210,7 +209,7 @@ var _ = Describe("Single Cluster Record Test", func() { g.Expect(err).NotTo(HaveOccurred()) g.Expect(dnsRecord.Status.Conditions).To( ContainElement(MatchFields(IgnoreExtras, Fields{ - "Type": Equal(string(conditions.ConditionTypeReady)), + "Type": Equal(string(v1alpha1.ConditionTypeReady)), "Status": Equal(metav1.ConditionTrue), })), ) @@ -362,7 +361,7 @@ var _ = Describe("Single Cluster Record Test", func() { g.Expect(err).NotTo(HaveOccurred()) g.Expect(dnsRecord.Status.Conditions).To( ContainElement(MatchFields(IgnoreExtras, Fields{ - "Type": Equal(string(conditions.ConditionTypeReady)), + "Type": Equal(string(v1alpha1.ConditionTypeReady)), "Status": Equal(metav1.ConditionTrue), })), ) @@ -495,7 +494,7 @@ var _ = Describe("Single Cluster Record Test", func() { g.Expect(err).NotTo(HaveOccurred()) g.Expect(dnsRecord.Status.Conditions).To( ContainElement(MatchFields(IgnoreExtras, Fields{ - "Type": Equal(string(conditions.ConditionTypeReady)), + "Type": Equal(string(v1alpha1.ConditionTypeReady)), "Status": Equal(metav1.ConditionTrue), })), )