From d750a66f9f81cd0e613e87988d4f5a7931ff2273 Mon Sep 17 00:00:00 2001 From: Dario Tranchitella Date: Sat, 7 Aug 2021 20:38:28 +0200 Subject: [PATCH] test(e2e): fixing flakiness for Service and EP metadata --- e2e/service_metadata_test.go | 72 +++++++++++++++++++++++++----------- 1 file changed, 51 insertions(+), 21 deletions(-) diff --git a/e2e/service_metadata_test.go b/e2e/service_metadata_test.go index c35c3a5b9..341b63fd6 100644 --- a/e2e/service_metadata_test.go +++ b/e2e/service_metadata_test.go @@ -8,17 +8,15 @@ package e2e import ( "context" + capsulev1beta1 "github.com/clastix/capsule/api/v1beta1" . "github.com/onsi/ginkgo" . "github.com/onsi/gomega" corev1 "k8s.io/api/core/v1" discoveryv1beta1 "k8s.io/api/discovery/v1beta1" - rbacv1 "k8s.io/api/rbac/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" "k8s.io/apimachinery/pkg/util/intstr" "k8s.io/utils/pointer" - - capsulev1beta1 "github.com/clastix/capsule/api/v1beta1" ) var _ = Describe("adding metadata to Service objects", func() { @@ -45,26 +43,17 @@ var _ = Describe("adding metadata to Service objects", func() { }, }, }, - AdditionalRoleBindings: []capsulev1beta1.AdditionalRoleBindingsSpec{ - { - ClusterRoleName: "system:controller:endpointslice-controller", - Subjects: []rbacv1.Subject{ - { - Kind: "User", - Name: "gatsby", - }, - }, - }, - }, }, } JustBeforeEach(func() { EventuallyCreation(func() error { + tnt.ResourceVersion = "" return k8sClient.Create(context.TODO(), tnt) }).Should(Succeed()) }) + JustAfterEach(func() { Expect(k8sClient.Delete(context.TODO(), tnt)).Should(Succeed()) }) @@ -93,8 +82,11 @@ var _ = Describe("adding metadata to Service objects", func() { }, }, } - EventuallyCreation(func() error { - return k8sClient.Create(context.TODO(), svc) + + EventuallyCreation(func() (err error) { + _, err = ownerClient(tnt.Spec.Owners[0]).CoreV1().Services(ns.GetName()).Create(context.Background(), svc, metav1.CreateOptions{}) + + return }).Should(Succeed()) By("checking additional labels", func() { @@ -109,6 +101,7 @@ var _ = Describe("adding metadata to Service objects", func() { return true }, defaultTimeoutInterval, defaultPollInterval).Should(BeTrue()) }) + By("checking additional annotations", func() { Eventually(func() (ok bool) { Expect(k8sClient.Get(context.TODO(), types.NamespacedName{Name: svc.GetName(), Namespace: ns.GetName()}, svc)).Should(Succeed()) @@ -149,9 +142,26 @@ var _ = Describe("adding metadata to Service objects", func() { }, }, } - EventuallyCreation(func() error { - return k8sClient.Create(context.TODO(), ep) + + EventuallyCreation(func() (err error) { + pod := &corev1.Pod{ + ObjectMeta: metav1.ObjectMeta{ + Name: "container", + }, + Spec: corev1.PodSpec{ + Containers: []corev1.Container{ + { + Name: "container", + Image: "quay.io/google-containers/pause-amd64:3.0", + }, + }, + }, + } + _, err = ownerClient(tnt.Spec.Owners[0]).CoreV1().Pods(ns.GetName()).Create(context.Background(), pod, metav1.CreateOptions{}) + + return }).Should(Succeed()) + By("checking additional labels", func() { Eventually(func() (ok bool) { Expect(k8sClient.Get(context.TODO(), types.NamespacedName{Name: ep.GetName(), Namespace: ns.GetName()}, ep)).Should(Succeed()) @@ -164,6 +174,7 @@ var _ = Describe("adding metadata to Service objects", func() { return true }, defaultTimeoutInterval, defaultPollInterval).Should(BeTrue()) }) + By("checking additional annotations", func() { Eventually(func() (ok bool) { Expect(k8sClient.Get(context.TODO(), types.NamespacedName{Name: ep.GetName(), Namespace: ns.GetName()}, ep)).Should(Succeed()) @@ -179,8 +190,7 @@ var _ = Describe("adding metadata to Service objects", func() { }) It("should apply them to EndpointSlice", func() { - maj, min, v := GetKubernetesSemVer() - if maj == 1 && min <= 16 { + if maj, min, v := GetKubernetesSemVer(); maj == 1 && min <= 16 { Skip("Running test on Kubernetes " + v + ", doesn't provide EndpointSlice resource") } @@ -206,8 +216,27 @@ var _ = Describe("adding metadata to Service objects", func() { }, }, } + // Waiting for the reconciliation of required RBAC + EventuallyCreation(func() (err error) { + pod := &corev1.Pod{ + ObjectMeta: metav1.ObjectMeta{ + Name: "container", + }, + Spec: corev1.PodSpec{ + Containers: []corev1.Container{ + { + Name: "container", + Image: "quay.io/google-containers/pause-amd64:3.0", + }, + }, + }, + } + _, err = ownerClient(tnt.Spec.Owners[0]).CoreV1().Pods(ns.GetName()).Create(context.Background(), pod, metav1.CreateOptions{}) - EventuallyCreation(func() error { + return + }).Should(Succeed()) + + EventuallyCreation(func() (err error) { return k8sClient.Create(context.TODO(), eps) }).Should(Succeed()) @@ -223,6 +252,7 @@ var _ = Describe("adding metadata to Service objects", func() { return true }, defaultTimeoutInterval, defaultPollInterval).Should(BeTrue()) }) + By("checking additional labels on EndpointSlice", func() { Eventually(func() (ok bool) { Expect(k8sClient.Get(context.TODO(), types.NamespacedName{Name: eps.GetName(), Namespace: ns.GetName()}, eps)).Should(Succeed())