mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-04 01:40:07 +00:00
Drop the use of watchtools
The thing is, for this test at least, I'm pretty sure there's nothing we need to wait on. Instead of waiting for a deleted event, we will relist configmaps and expect 0, to confirm the deletion took effect
This commit is contained in:
parent
0a869ac043
commit
121676e220
@ -58,7 +58,6 @@ go_library(
|
|||||||
"//staging/src/k8s.io/apimachinery/pkg/fields:go_default_library",
|
"//staging/src/k8s.io/apimachinery/pkg/fields:go_default_library",
|
||||||
"//staging/src/k8s.io/apimachinery/pkg/labels:go_default_library",
|
"//staging/src/k8s.io/apimachinery/pkg/labels:go_default_library",
|
||||||
"//staging/src/k8s.io/apimachinery/pkg/runtime:go_default_library",
|
"//staging/src/k8s.io/apimachinery/pkg/runtime:go_default_library",
|
||||||
"//staging/src/k8s.io/apimachinery/pkg/runtime/schema:go_default_library",
|
|
||||||
"//staging/src/k8s.io/apimachinery/pkg/types:go_default_library",
|
"//staging/src/k8s.io/apimachinery/pkg/types:go_default_library",
|
||||||
"//staging/src/k8s.io/apimachinery/pkg/util/diff:go_default_library",
|
"//staging/src/k8s.io/apimachinery/pkg/util/diff:go_default_library",
|
||||||
"//staging/src/k8s.io/apimachinery/pkg/util/intstr:go_default_library",
|
"//staging/src/k8s.io/apimachinery/pkg/util/intstr:go_default_library",
|
||||||
@ -67,7 +66,6 @@ go_library(
|
|||||||
"//staging/src/k8s.io/apimachinery/pkg/util/uuid:go_default_library",
|
"//staging/src/k8s.io/apimachinery/pkg/util/uuid:go_default_library",
|
||||||
"//staging/src/k8s.io/apimachinery/pkg/util/wait:go_default_library",
|
"//staging/src/k8s.io/apimachinery/pkg/util/wait:go_default_library",
|
||||||
"//staging/src/k8s.io/apimachinery/pkg/watch:go_default_library",
|
"//staging/src/k8s.io/apimachinery/pkg/watch:go_default_library",
|
||||||
"//staging/src/k8s.io/client-go/dynamic:go_default_library",
|
|
||||||
"//staging/src/k8s.io/client-go/kubernetes:go_default_library",
|
"//staging/src/k8s.io/client-go/kubernetes:go_default_library",
|
||||||
"//staging/src/k8s.io/client-go/tools/cache:go_default_library",
|
"//staging/src/k8s.io/client-go/tools/cache:go_default_library",
|
||||||
"//staging/src/k8s.io/client-go/tools/watch:go_default_library",
|
"//staging/src/k8s.io/client-go/tools/watch:go_default_library",
|
||||||
|
@ -20,16 +20,11 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"time"
|
|
||||||
|
|
||||||
v1 "k8s.io/api/core/v1"
|
v1 "k8s.io/api/core/v1"
|
||||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||||
"k8s.io/apimachinery/pkg/types"
|
"k8s.io/apimachinery/pkg/types"
|
||||||
"k8s.io/apimachinery/pkg/util/uuid"
|
"k8s.io/apimachinery/pkg/util/uuid"
|
||||||
watch "k8s.io/apimachinery/pkg/watch"
|
|
||||||
"k8s.io/client-go/dynamic"
|
|
||||||
"k8s.io/client-go/tools/cache"
|
|
||||||
watchtools "k8s.io/client-go/tools/watch"
|
|
||||||
"k8s.io/kubernetes/test/e2e/framework"
|
"k8s.io/kubernetes/test/e2e/framework"
|
||||||
imageutils "k8s.io/kubernetes/test/utils/image"
|
imageutils "k8s.io/kubernetes/test/utils/image"
|
||||||
|
|
||||||
@ -39,12 +34,6 @@ import (
|
|||||||
var _ = ginkgo.Describe("[sig-node] ConfigMap", func() {
|
var _ = ginkgo.Describe("[sig-node] ConfigMap", func() {
|
||||||
f := framework.NewDefaultFramework("configmap")
|
f := framework.NewDefaultFramework("configmap")
|
||||||
|
|
||||||
var dc dynamic.Interface
|
|
||||||
|
|
||||||
ginkgo.BeforeEach(func() {
|
|
||||||
dc = f.DynamicClient
|
|
||||||
})
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Release : v1.9
|
Release : v1.9
|
||||||
Testname: ConfigMap, from environment field
|
Testname: ConfigMap, from environment field
|
||||||
@ -184,37 +173,10 @@ var _ = ginkgo.Describe("[sig-node] ConfigMap", func() {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
w := &cache.ListWatch{
|
|
||||||
WatchFunc: func(options metav1.ListOptions) (watch.Interface, error) {
|
|
||||||
options.LabelSelector = "test-configmap-static=true"
|
|
||||||
return f.ClientSet.CoreV1().ConfigMaps(testNamespaceName).Watch(context.TODO(), options)
|
|
||||||
},
|
|
||||||
}
|
|
||||||
cml, err := f.ClientSet.CoreV1().ConfigMaps(testNamespaceName).List(context.TODO(), metav1.ListOptions{LabelSelector: "test-configmap-static=true"})
|
|
||||||
framework.ExpectNoError(err)
|
|
||||||
|
|
||||||
ginkgo.By("creating a ConfigMap")
|
ginkgo.By("creating a ConfigMap")
|
||||||
cm, err := f.ClientSet.CoreV1().ConfigMaps(testNamespaceName).Create(context.TODO(), &testConfigMap, metav1.CreateOptions{})
|
_, err := f.ClientSet.CoreV1().ConfigMaps(testNamespaceName).Create(context.TODO(), &testConfigMap, metav1.CreateOptions{})
|
||||||
framework.ExpectNoError(err, "failed to create ConfigMap")
|
framework.ExpectNoError(err, "failed to create ConfigMap")
|
||||||
|
|
||||||
ctx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
|
|
||||||
defer cancel()
|
|
||||||
_, err = watchtools.Until(ctx, cml.ResourceVersion, w, func(event watch.Event) (bool, error) {
|
|
||||||
switch event.Type {
|
|
||||||
case watch.Added:
|
|
||||||
if cm, ok := event.Object.(*v1.ConfigMap); ok {
|
|
||||||
found := cm.ObjectMeta.Name == testConfigMap.Name &&
|
|
||||||
cm.Labels["test-configmap-static"] == "true" &&
|
|
||||||
cm.Data["valueName"] == "value"
|
|
||||||
return found, nil
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
framework.Logf("observed event type %v", event.Type)
|
|
||||||
}
|
|
||||||
return false, nil
|
|
||||||
})
|
|
||||||
framework.ExpectNoError(err, "failed to see a watch.Added event for the configmap we created")
|
|
||||||
|
|
||||||
configMapPatchPayload, err := json.Marshal(v1.ConfigMap{
|
configMapPatchPayload, err := json.Marshal(v1.ConfigMap{
|
||||||
ObjectMeta: metav1.ObjectMeta{
|
ObjectMeta: metav1.ObjectMeta{
|
||||||
Labels: map[string]string{
|
Labels: map[string]string{
|
||||||
@ -228,27 +190,8 @@ var _ = ginkgo.Describe("[sig-node] ConfigMap", func() {
|
|||||||
framework.ExpectNoError(err, "failed to marshal patch data")
|
framework.ExpectNoError(err, "failed to marshal patch data")
|
||||||
|
|
||||||
ginkgo.By("patching the ConfigMap")
|
ginkgo.By("patching the ConfigMap")
|
||||||
cm2, err := f.ClientSet.CoreV1().ConfigMaps(testNamespaceName).Patch(context.TODO(), testConfigMapName, types.StrategicMergePatchType, []byte(configMapPatchPayload), metav1.PatchOptions{})
|
_, err = f.ClientSet.CoreV1().ConfigMaps(testNamespaceName).Patch(context.TODO(), testConfigMapName, types.StrategicMergePatchType, []byte(configMapPatchPayload), metav1.PatchOptions{})
|
||||||
framework.ExpectNoError(err, "failed to patch ConfigMap")
|
framework.ExpectNoError(err, "failed to patch ConfigMap")
|
||||||
ginkgo.By("waiting for the ConfigMap to be modified")
|
|
||||||
ctx, cancel = context.WithTimeout(context.Background(), 30*time.Second)
|
|
||||||
defer cancel()
|
|
||||||
_, err = watchtools.Until(ctx, cm.ResourceVersion, w, func(event watch.Event) (bool, error) {
|
|
||||||
switch event.Type {
|
|
||||||
case watch.Modified:
|
|
||||||
if cm, ok := event.Object.(*v1.ConfigMap); ok {
|
|
||||||
found := cm.ObjectMeta.Name == testConfigMap.Name &&
|
|
||||||
cm.Labels["test-configmap-static"] == "true" &&
|
|
||||||
cm.Labels["test-configmap"] == "patched" &&
|
|
||||||
cm.Data["valueName"] == "value1"
|
|
||||||
return found, nil
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
framework.Logf("observed event type %v", event.Type)
|
|
||||||
}
|
|
||||||
return false, nil
|
|
||||||
})
|
|
||||||
framework.ExpectNoError(err, "failed to see a watch.Modified event for the configmap we patched")
|
|
||||||
|
|
||||||
ginkgo.By("fetching the ConfigMap")
|
ginkgo.By("fetching the ConfigMap")
|
||||||
configMap, err := f.ClientSet.CoreV1().ConfigMaps(testNamespaceName).Get(context.TODO(), testConfigMapName, metav1.GetOptions{})
|
configMap, err := f.ClientSet.CoreV1().ConfigMaps(testNamespaceName).Get(context.TODO(), testConfigMapName, metav1.GetOptions{})
|
||||||
@ -279,25 +222,11 @@ var _ = ginkgo.Describe("[sig-node] ConfigMap", func() {
|
|||||||
LabelSelector: "test-configmap-static=true",
|
LabelSelector: "test-configmap-static=true",
|
||||||
})
|
})
|
||||||
framework.ExpectNoError(err, "failed to delete ConfigMap collection with LabelSelector")
|
framework.ExpectNoError(err, "failed to delete ConfigMap collection with LabelSelector")
|
||||||
ginkgo.By("waiting for the ConfigMap to be deleted")
|
ginkgo.By("listing all ConfigMaps in all namespaces")
|
||||||
ctx, cancel = context.WithTimeout(context.Background(), 30*time.Second)
|
configMapList, err = f.ClientSet.CoreV1().ConfigMaps("").List(context.TODO(), metav1.ListOptions{
|
||||||
defer cancel()
|
LabelSelector: "test-configmap-static=true",
|
||||||
_, err = watchtools.Until(ctx, cm2.ResourceVersion, w, func(event watch.Event) (bool, error) {
|
|
||||||
switch event.Type {
|
|
||||||
case watch.Deleted:
|
|
||||||
if cm, ok := event.Object.(*v1.ConfigMap); ok {
|
|
||||||
found := cm.ObjectMeta.Name == testConfigMap.Name &&
|
|
||||||
cm.Labels["test-configmap-static"] == "true" &&
|
|
||||||
cm.Labels["test-configmap"] == "patched" &&
|
|
||||||
cm.Data["valueName"] == "value1"
|
|
||||||
return found, nil
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
framework.Logf("observed event type %v", event.Type)
|
|
||||||
}
|
|
||||||
return false, nil
|
|
||||||
})
|
})
|
||||||
framework.ExpectNoError(err, "fasiled to observe a watch.Deleted event for the ConfigMap we deleted")
|
framework.ExpectEqual(len(configMapList.Items), 0, "ConfigMap is still present after being deleted by collection")
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user