Skip to content

Commit 69b648a

Browse files
authored
Merge pull request kubernetes#124223 from chenk008/fix_apf_countTracker
Fix: EtcdOptions.StorageObjectCountTracker is nil, APF estimator got ObjectCountNotFoundErr
2 parents bf07ef3 + c5d0e59 commit 69b648a

File tree

4 files changed

+96
-0
lines changed

4 files changed

+96
-0
lines changed

pkg/controlplane/apiserver/config.go

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -140,6 +140,9 @@ func BuildGenericConfig(
140140
if lastErr != nil {
141141
return
142142
}
143+
// storageFactory.StorageConfig is copied from etcdOptions.StorageConfig,
144+
// the StorageObjectCountTracker is still nil. Here we copy from genericConfig.
145+
storageFactory.StorageConfig.StorageObjectCountTracker = genericConfig.StorageObjectCountTracker
143146
if lastErr = s.Etcd.ApplyWithStorageFactoryTo(storageFactory, genericConfig); lastErr != nil {
144147
return
145148
}
Lines changed: 74 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,74 @@
1+
/*
2+
Copyright 2024 The Kubernetes Authors.
3+
4+
Licensed under the Apache License, Version 2.0 (the "License");
5+
you may not use this file except in compliance with the License.
6+
You may obtain a copy of the License at
7+
8+
http://www.apache.org/licenses/LICENSE-2.0
9+
10+
Unless required by applicable law or agreed to in writing, software
11+
distributed under the License is distributed on an "AS IS" BASIS,
12+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
See the License for the specific language governing permissions and
14+
limitations under the License.
15+
*/
16+
17+
package apiserver
18+
19+
import (
20+
extensionsapiserver "k8s.io/apiextensions-apiserver/pkg/apiserver"
21+
"k8s.io/apimachinery/pkg/runtime"
22+
"k8s.io/apimachinery/pkg/runtime/schema"
23+
apiserveroptions "k8s.io/apiserver/pkg/server/options"
24+
aggregatorscheme "k8s.io/kube-aggregator/pkg/apiserver/scheme"
25+
"k8s.io/kubernetes/pkg/api/legacyscheme"
26+
"k8s.io/kubernetes/pkg/controlplane/apiserver/options"
27+
generatedopenapi "k8s.io/kubernetes/pkg/generated/openapi"
28+
netutils "k8s.io/utils/net"
29+
"net"
30+
"testing"
31+
)
32+
33+
func TestBuildGenericConfig(t *testing.T) {
34+
opts := options.NewOptions()
35+
s := (&apiserveroptions.SecureServingOptions{
36+
BindAddress: netutils.ParseIPSloppy("127.0.0.1"),
37+
}).WithLoopback()
38+
ln, err := net.Listen("tcp", "127.0.0.1:0")
39+
if err != nil {
40+
t.Fatalf("failed to listen on 127.0.0.1:0")
41+
}
42+
defer ln.Close()
43+
s.Listener = ln
44+
s.BindPort = ln.Addr().(*net.TCPAddr).Port
45+
opts.SecureServing = s
46+
47+
completedOptions, err := opts.Complete(nil, nil)
48+
if err != nil {
49+
t.Fatalf("Failed to complete apiserver options: %v", err)
50+
}
51+
52+
genericConfig, _, storageFactory, err := BuildGenericConfig(
53+
completedOptions,
54+
[]*runtime.Scheme{legacyscheme.Scheme, extensionsapiserver.Scheme, aggregatorscheme.Scheme},
55+
generatedopenapi.GetOpenAPIDefinitions,
56+
)
57+
if err != nil {
58+
t.Fatalf("Failed to build generic config: %v", err)
59+
}
60+
if genericConfig.StorageObjectCountTracker == nil {
61+
t.Errorf("genericConfig StorageObjectCountTracker is absent")
62+
}
63+
if genericConfig.StorageObjectCountTracker != storageFactory.StorageConfig.StorageObjectCountTracker {
64+
t.Errorf("There are different StorageObjectCountTracker in genericConfig and storageFactory")
65+
}
66+
67+
restOptions, err := genericConfig.RESTOptionsGetter.GetRESTOptions(schema.GroupResource{Group: "", Resource: ""})
68+
if err != nil {
69+
t.Fatal(err)
70+
}
71+
if restOptions.StorageConfig.StorageObjectCountTracker != genericConfig.StorageObjectCountTracker {
72+
t.Errorf("There are different StorageObjectCountTracker in restOptions and serverConfig")
73+
}
74+
}

staging/src/k8s.io/apiserver/pkg/server/options/etcd.go

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -399,6 +399,10 @@ func (f *StorageFactoryRestOptionsFactory) GetRESTOptions(resource schema.GroupR
399399
StorageObjectCountTracker: f.Options.StorageConfig.StorageObjectCountTracker,
400400
}
401401

402+
if ret.StorageObjectCountTracker == nil {
403+
ret.StorageObjectCountTracker = storageConfig.StorageObjectCountTracker
404+
}
405+
402406
if f.Options.EnableWatchCache {
403407
sizes, err := ParseWatchCacheSizes(f.Options.WatchCacheSizes)
404408
if err != nil {

staging/src/k8s.io/apiserver/pkg/server/options/etcd_test.go

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -430,3 +430,18 @@ func healthChecksAreEqual(t *testing.T, want []string, healthChecks []healthz.He
430430
t.Errorf("%s checks are not equal, missing=%q, extra=%q", checkerType, wantSet.Difference(gotSet).List(), gotSet.Difference(wantSet).List())
431431
}
432432
}
433+
434+
func TestRestOptionsStorageObjectCountTracker(t *testing.T) {
435+
serverConfig := server.NewConfig(codecs)
436+
etcdOptions := &EtcdOptions{}
437+
if err := etcdOptions.ApplyTo(serverConfig); err != nil {
438+
t.Fatalf("Failed to apply etcd options error: %v", err)
439+
}
440+
restOptions, err := serverConfig.RESTOptionsGetter.GetRESTOptions(schema.GroupResource{Group: "", Resource: ""})
441+
if err != nil {
442+
t.Fatal(err)
443+
}
444+
if restOptions.StorageConfig.StorageObjectCountTracker != serverConfig.StorageObjectCountTracker {
445+
t.Errorf("There are different StorageObjectCountTracker in restOptions and serverConfig")
446+
}
447+
}

0 commit comments

Comments
 (0)