Skip to content

Commit d195ea8

Browse files
committed
fake/clientset: improve TestNewSimpleClientset
1 parent 20b12ad commit d195ea8

File tree

1 file changed

+31
-41
lines changed

1 file changed

+31
-41
lines changed

staging/src/k8s.io/client-go/kubernetes/fake/clientset_generated_test.go

Lines changed: 31 additions & 41 deletions
Original file line numberDiff line numberDiff line change
@@ -18,9 +18,11 @@ package fake
1818

1919
import (
2020
"context"
21-
"github.com/stretchr/testify/assert"
2221
"testing"
2322

23+
"github.com/google/go-cmp/cmp"
24+
"github.com/stretchr/testify/require"
25+
2426
v1 "k8s.io/api/core/v1"
2527
policy "k8s.io/api/policy/v1"
2628
meta_v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
@@ -29,35 +31,36 @@ import (
2931

3032
func TestNewSimpleClientset(t *testing.T) {
3133
client := NewSimpleClientset()
32-
client.CoreV1().Pods("default").Create(context.Background(), &v1.Pod{
34+
expectedPods := []*v1.Pod{}
35+
36+
pod, err := client.CoreV1().Pods("default").Create(context.Background(), &v1.Pod{
3337
ObjectMeta: meta_v1.ObjectMeta{
3438
Name: "pod-1",
3539
Namespace: "default",
3640
},
3741
}, meta_v1.CreateOptions{})
38-
client.CoreV1().Pods("default").Create(context.Background(), &v1.Pod{
42+
require.NoError(t, err)
43+
expectedPods = append(expectedPods, pod)
44+
45+
pod, err = client.CoreV1().Pods("default").Create(context.Background(), &v1.Pod{
3946
ObjectMeta: meta_v1.ObjectMeta{
4047
Name: "pod-2",
4148
Namespace: "default",
4249
},
4350
}, meta_v1.CreateOptions{})
44-
err := client.CoreV1().Pods("default").EvictV1(context.Background(), &policy.Eviction{
51+
require.NoError(t, err)
52+
expectedPods = append(expectedPods, pod)
53+
54+
err = client.CoreV1().Pods("default").EvictV1(context.Background(), &policy.Eviction{
4555
ObjectMeta: meta_v1.ObjectMeta{
4656
Name: "pod-2",
4757
},
4858
})
49-
50-
if err != nil {
51-
t.Errorf("TestNewSimpleClientset() res = %v", err.Error())
52-
}
59+
require.NoError(t, err)
5360

5461
pods, err := client.CoreV1().Pods("default").List(context.Background(), meta_v1.ListOptions{})
55-
// err: item[0]: can't assign or convert v1beta1.Eviction into v1.Pod
56-
if err != nil {
57-
t.Errorf("TestNewSimpleClientset() res = %v", err.Error())
58-
} else {
59-
t.Logf("TestNewSimpleClientset() res = %v", pods)
60-
}
62+
require.NoError(t, err)
63+
cmp.Equal(expectedPods, pods.Items)
6164
}
6265

6366
func TestManagedFieldClientset(t *testing.T) {
@@ -69,58 +72,47 @@ func TestManagedFieldClientset(t *testing.T) {
6972
ObjectMeta: meta_v1.ObjectMeta{Name: name, Namespace: namespace},
7073
Data: map[string]string{"k0": "v0"},
7174
}, meta_v1.CreateOptions{FieldManager: "test-manager-0"})
72-
if err != nil {
73-
t.Errorf("Failed to create pod: %v", err)
74-
}
75-
assert.Equal(t, map[string]string{"k0": "v0"}, cm.Data)
75+
require.NoError(t, err)
76+
require.Equal(t, map[string]string{"k0": "v0"}, cm.Data)
7677

7778
// Apply with test-manager-1
7879
// Expect data to be shared with initial create
7980
cm, err = client.CoreV1().ConfigMaps("default").Apply(context.Background(),
8081
v1ac.ConfigMap(name, namespace).WithData(map[string]string{"k1": "v1"}),
8182
meta_v1.ApplyOptions{FieldManager: "test-manager-1"})
82-
if err != nil {
83-
t.Errorf("Failed to create pod: %v", err)
84-
}
85-
assert.Equal(t, map[string]string{"k0": "v0", "k1": "v1"}, cm.Data)
83+
require.NoError(t, err)
84+
require.Equal(t, map[string]string{"k0": "v0", "k1": "v1"}, cm.Data)
8685

8786
// Apply conflicting with test-manager-2, expect apply to fail
8887
_, err = client.CoreV1().ConfigMaps("default").Apply(context.Background(),
8988
v1ac.ConfigMap(name, namespace).WithData(map[string]string{"k1": "xyz"}),
9089
meta_v1.ApplyOptions{FieldManager: "test-manager-2"})
91-
if assert.Error(t, err) {
92-
assert.Equal(t, "Apply failed with 1 conflict: conflict with \"test-manager-1\": .data.k1", err.Error())
93-
}
90+
require.Error(t, err)
91+
require.Equal(t, "Apply failed with 1 conflict: conflict with \"test-manager-1\": .data.k1", err.Error())
9492

9593
// Apply with test-manager-2
9694
// Expect data to be shared with initial create and test-manager-1
9795
cm, err = client.CoreV1().ConfigMaps("default").Apply(context.Background(),
9896
v1ac.ConfigMap(name, namespace).WithData(map[string]string{"k2": "v2"}),
9997
meta_v1.ApplyOptions{FieldManager: "test-manager-2"})
100-
if err != nil {
101-
t.Errorf("Failed to create pod: %v", err)
102-
}
103-
assert.Equal(t, map[string]string{"k0": "v0", "k1": "v1", "k2": "v2"}, cm.Data)
98+
require.NoError(t, err)
99+
require.Equal(t, map[string]string{"k0": "v0", "k1": "v1", "k2": "v2"}, cm.Data)
104100

105101
// Apply with test-manager-1
106102
// Expect owned data to be updated
107103
cm, err = client.CoreV1().ConfigMaps("default").Apply(context.Background(),
108104
v1ac.ConfigMap(name, namespace).WithData(map[string]string{"k1": "v101"}),
109105
meta_v1.ApplyOptions{FieldManager: "test-manager-1"})
110-
if err != nil {
111-
t.Errorf("Failed to create pod: %v", err)
112-
}
113-
assert.Equal(t, map[string]string{"k0": "v0", "k1": "v101", "k2": "v2"}, cm.Data)
106+
require.NoError(t, err)
107+
require.Equal(t, map[string]string{"k0": "v0", "k1": "v101", "k2": "v2"}, cm.Data)
114108

115109
// Force apply with test-manager-2
116110
// Expect data owned by test-manager-1 to be updated, expect data already owned but not in apply configuration to be removed
117111
cm, err = client.CoreV1().ConfigMaps("default").Apply(context.Background(),
118112
v1ac.ConfigMap(name, namespace).WithData(map[string]string{"k1": "v202"}),
119113
meta_v1.ApplyOptions{FieldManager: "test-manager-2", Force: true})
120-
if err != nil {
121-
t.Errorf("Failed to create pod: %v", err)
122-
}
123-
assert.Equal(t, map[string]string{"k0": "v0", "k1": "v202"}, cm.Data)
114+
require.NoError(t, err)
115+
require.Equal(t, map[string]string{"k0": "v0", "k1": "v202"}, cm.Data)
124116

125117
// Update with test-manager-1 to perform a force update of the entire resource
126118
cm, err = client.CoreV1().ConfigMaps("default").Update(context.Background(),
@@ -137,8 +129,6 @@ func TestManagedFieldClientset(t *testing.T) {
137129
"k99": "v99",
138130
},
139131
}, meta_v1.UpdateOptions{FieldManager: "test-manager-0"})
140-
if err != nil {
141-
t.Errorf("Failed to update pod: %v", err)
142-
}
143-
assert.Equal(t, map[string]string{"k99": "v99"}, cm.Data)
132+
require.NoError(t, err)
133+
require.Equal(t, map[string]string{"k99": "v99"}, cm.Data)
144134
}

0 commit comments

Comments
 (0)