From 610bb31799a46507ef0148d6d2b3a0188f93d8dd Mon Sep 17 00:00:00 2001 From: killianmuldoon Date: Tue, 22 Aug 2023 18:31:25 +0100 Subject: [PATCH] Add test for ownerReference apiVersion update Signed-off-by: killianmuldoon --- test/e2e/clusterctl_upgrade_test.go | 57 ------------------------ test/e2e/quick_start_test.go | 18 ++++++++ test/framework/ownerreference_helpers.go | 46 ++++++++++++++++++- 3 files changed, 62 insertions(+), 59 deletions(-) diff --git a/test/e2e/clusterctl_upgrade_test.go b/test/e2e/clusterctl_upgrade_test.go index 8df575442d6d..f3cf39b199f9 100644 --- a/test/e2e/clusterctl_upgrade_test.go +++ b/test/e2e/clusterctl_upgrade_test.go @@ -22,8 +22,6 @@ package e2e import ( . "github.com/onsi/ginkgo/v2" "k8s.io/utils/pointer" - - "sigs.k8s.io/cluster-api/test/framework" ) var _ = Describe("When testing clusterctl upgrades (v0.4=>current)", func() { @@ -82,17 +80,6 @@ var _ = Describe("When testing clusterctl upgrades (v1.0=>current)", func() { WorkloadKubernetesVersion: "v1.23.17", MgmtFlavor: "topology", WorkloadFlavor: "", - // This check ensures that ownerReference apiVersions are updated for all types after the upgrade. - PostUpgrade: func(proxy framework.ClusterProxy, namespace, clusterName string) { - framework.ValidateOwnerReferencesOnUpdate(proxy, namespace, - framework.CoreOwnerReferenceAssertion, - framework.ExpOwnerReferenceAssertions, - framework.DockerInfraOwnerReferenceAssertions, - framework.KubeadmBootstrapOwnerReferenceAssertions, - framework.KubeadmControlPlaneOwnerReferenceAssertions, - framework.KubernetesReferenceAssertions, - ) - }, } }) }) @@ -123,17 +110,6 @@ var _ = Describe("When testing clusterctl upgrades (v1.3=>current)", func() { WorkloadKubernetesVersion: "v1.26.4", MgmtFlavor: "topology", WorkloadFlavor: "", - // This check ensures that ownerReference apiVersions are updated for all types after the upgrade. - PostUpgrade: func(proxy framework.ClusterProxy, namespace, clusterName string) { - framework.ValidateOwnerReferencesOnUpdate(proxy, namespace, - framework.CoreOwnerReferenceAssertion, - framework.ExpOwnerReferenceAssertions, - framework.DockerInfraOwnerReferenceAssertions, - framework.KubeadmBootstrapOwnerReferenceAssertions, - framework.KubeadmControlPlaneOwnerReferenceAssertions, - framework.KubernetesReferenceAssertions, - ) - }, } }) }) @@ -164,17 +140,6 @@ var _ = Describe("When testing clusterctl upgrades using ClusterClass (v1.3=>cur WorkloadKubernetesVersion: "v1.26.4", MgmtFlavor: "topology", WorkloadFlavor: "topology", - // This check ensures that ownerReference apiVersions are updated for all types after the upgrade. - PostUpgrade: func(proxy framework.ClusterProxy, namespace, clusterName string) { - framework.ValidateOwnerReferencesOnUpdate(proxy, namespace, - framework.CoreOwnerReferenceAssertion, - framework.ExpOwnerReferenceAssertions, - framework.DockerInfraOwnerReferenceAssertions, - framework.KubeadmBootstrapOwnerReferenceAssertions, - framework.KubeadmControlPlaneOwnerReferenceAssertions, - framework.KubernetesReferenceAssertions, - ) - }, } }) }) @@ -195,17 +160,6 @@ var _ = Describe("When testing clusterctl upgrades (v1.4=>current)", func() { WorkloadKubernetesVersion: "v1.27.3", MgmtFlavor: "topology", WorkloadFlavor: "", - // This check ensures that ownerReference apiVersions are updated for all types after the upgrade. - PostUpgrade: func(proxy framework.ClusterProxy, namespace, clusterName string) { - framework.ValidateOwnerReferencesOnUpdate(proxy, namespace, - framework.CoreOwnerReferenceAssertion, - framework.ExpOwnerReferenceAssertions, - framework.DockerInfraOwnerReferenceAssertions, - framework.KubeadmBootstrapOwnerReferenceAssertions, - framework.KubeadmControlPlaneOwnerReferenceAssertions, - framework.KubernetesReferenceAssertions, - ) - }, } }) }) @@ -226,17 +180,6 @@ var _ = Describe("When testing clusterctl upgrades using ClusterClass (v1.4=>cur WorkloadKubernetesVersion: "v1.27.3", MgmtFlavor: "topology", WorkloadFlavor: "topology", - // This check ensures that ownerReference apiVersions are updated for all types after the upgrade. - PostUpgrade: func(proxy framework.ClusterProxy, namespace, clusterName string) { - framework.ValidateOwnerReferencesOnUpdate(proxy, namespace, - framework.CoreOwnerReferenceAssertion, - framework.ExpOwnerReferenceAssertions, - framework.DockerInfraOwnerReferenceAssertions, - framework.KubeadmBootstrapOwnerReferenceAssertions, - framework.KubeadmControlPlaneOwnerReferenceAssertions, - framework.KubernetesReferenceAssertions, - ) - }, } }) }) diff --git a/test/e2e/quick_start_test.go b/test/e2e/quick_start_test.go index 04335920c6d3..0dc2fc495efe 100644 --- a/test/e2e/quick_start_test.go +++ b/test/e2e/quick_start_test.go @@ -47,6 +47,15 @@ var _ = Describe("When following the Cluster API quick-start", func() { framework.KubeadmControlPlaneOwnerReferenceAssertions, framework.KubernetesReferenceAssertions, ) + // This check ensures that owner references are correctly updated to the correct apiVersion. + framework.ValidateOwnerReferencesOnUpdate(ctx, proxy, namespace, clusterName, + framework.CoreOwnerReferenceAssertion, + framework.ExpOwnerReferenceAssertions, + framework.DockerInfraOwnerReferenceAssertions, + framework.KubeadmBootstrapOwnerReferenceAssertions, + framework.KubeadmControlPlaneOwnerReferenceAssertions, + framework.KubernetesReferenceAssertions, + ) }, } }) @@ -72,6 +81,15 @@ var _ = Describe("When following the Cluster API quick-start with ClusterClass [ framework.KubeadmControlPlaneOwnerReferenceAssertions, framework.KubernetesReferenceAssertions, ) + // This check ensures that owner references are correctly updated to the correct apiVersion. + framework.ValidateOwnerReferencesOnUpdate(ctx, proxy, namespace, clusterName, + framework.CoreOwnerReferenceAssertion, + framework.ExpOwnerReferenceAssertions, + framework.DockerInfraOwnerReferenceAssertions, + framework.KubeadmBootstrapOwnerReferenceAssertions, + framework.KubeadmControlPlaneOwnerReferenceAssertions, + framework.KubernetesReferenceAssertions, + ) }, } }) diff --git a/test/framework/ownerreference_helpers.go b/test/framework/ownerreference_helpers.go index e763fcc295c0..7d19bb5bfd1a 100644 --- a/test/framework/ownerreference_helpers.go +++ b/test/framework/ownerreference_helpers.go @@ -42,8 +42,22 @@ import ( ) // ValidateOwnerReferencesOnUpdate checks that expected owner references are updated to the correct apiVersion. -func ValidateOwnerReferencesOnUpdate(proxy ClusterProxy, namespace string, assertFuncs ...map[string]func(reference []metav1.OwnerReference) error) { - // Check that the ownerReferences are as expected on the first iteration. +func ValidateOwnerReferencesOnUpdate(ctx context.Context, proxy ClusterProxy, namespace, clusterName string, assertFuncs ...map[string]func(reference []metav1.OwnerReference) error) { + clusterKey := client.ObjectKey{Namespace: namespace, Name: clusterName} + + // Changes the version of all the owner references to v1alpha1. Expect the apiVersion to be updated after reconciliation. + setClusterPause(ctx, proxy.GetClient(), clusterKey, true) + + // Change the version of the OwnerReferences on each object in the Graph to "v1alpha1" + changeOwnerReferencesAPIVersion(ctx, proxy, namespace) + + setClusterPause(ctx, proxy.GetClient(), clusterKey, false) + + // Annotate the clusterClass, if one is in use, to speed up reconciliation. This ensures ClusterClass ownerReferences + // are re-reconciled before asserting the owner reference graph. + forceClusterClassReconcile(ctx, proxy.GetClient(), clusterKey) + + // Check that the ownerReferences have updated their apiVersions to current versions after reconciliation. AssertOwnerReferences(namespace, proxy.GetKubeconfigPath(), assertFuncs...) } @@ -351,6 +365,34 @@ func forceClusterClassReconcile(ctx context.Context, cli client.Client, clusterK } } +func changeOwnerReferencesAPIVersion(ctx context.Context, proxy ClusterProxy, namespace string) { + graph, err := clusterctlcluster.GetOwnerGraph(ctx, namespace, proxy.GetKubeconfigPath()) + Expect(err).ToNot(HaveOccurred()) + for _, object := range graph { + ref := object.Object + obj := new(unstructured.Unstructured) + obj.SetAPIVersion(ref.APIVersion) + obj.SetKind(ref.Kind) + obj.SetName(ref.Name) + + Expect(proxy.GetClient().Get(ctx, client.ObjectKey{Namespace: namespace, Name: object.Object.Name}, obj)).To(Succeed()) + helper, err := patch.NewHelper(obj, proxy.GetClient()) + Expect(err).ToNot(HaveOccurred()) + + newOwners := []metav1.OwnerReference{} + for _, owner := range obj.GetOwnerReferences() { + gv, err := schema.ParseGroupVersion(owner.APIVersion) + Expect(err).To(Succeed()) + gv.Version = "v1alpha1" + owner.APIVersion = gv.String() + newOwners = append(newOwners, owner) + } + + obj.SetOwnerReferences(newOwners) + Expect(helper.Patch(ctx, obj)).To(Succeed()) + } +} + func removeOwnerReferences(ctx context.Context, proxy ClusterProxy, namespace string) { graph, err := clusterctlcluster.GetOwnerGraph(namespace, proxy.GetKubeconfigPath()) Expect(err).ToNot(HaveOccurred())