mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-03 19:58:17 +00:00 
			
		
		
		
	kube-apiserver: fix missing global flags for --help
Signed-off-by: Jay Lim <jay@imjching.com>
This commit is contained in:
		@@ -23,9 +23,7 @@ go_library(
 | 
			
		||||
        "//pkg/client/metrics/prometheus:go_default_library",
 | 
			
		||||
        "//pkg/version/prometheus:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/server:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/flag:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/logs:go_default_library",
 | 
			
		||||
        "//vendor/github.com/spf13/pflag:go_default_library",
 | 
			
		||||
    ],
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -19,16 +19,12 @@ limitations under the License.
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	goflag "flag"
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"math/rand"
 | 
			
		||||
	"os"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
	"github.com/spf13/pflag"
 | 
			
		||||
 | 
			
		||||
	"k8s.io/apiserver/pkg/server"
 | 
			
		||||
	utilflag "k8s.io/apiserver/pkg/util/flag"
 | 
			
		||||
	"k8s.io/apiserver/pkg/util/logs"
 | 
			
		||||
	"k8s.io/kubernetes/cmd/kube-apiserver/app"
 | 
			
		||||
	_ "k8s.io/kubernetes/pkg/client/metrics/prometheus" // for client metric registration
 | 
			
		||||
@@ -43,8 +39,6 @@ func main() {
 | 
			
		||||
	// TODO: once we switch everything over to Cobra commands, we can go back to calling
 | 
			
		||||
	// utilflag.InitFlags() (by removing its pflag.Parse() call). For now, we have to set the
 | 
			
		||||
	// normalize func and add the go flag set by hand.
 | 
			
		||||
	pflag.CommandLine.SetNormalizeFunc(utilflag.WordSepNormalizeFunc)
 | 
			
		||||
	pflag.CommandLine.AddGoFlagSet(goflag.CommandLine)
 | 
			
		||||
	// utilflag.InitFlags()
 | 
			
		||||
	logs.InitLogs()
 | 
			
		||||
	defer logs.FlushLogs()
 | 
			
		||||
 
 | 
			
		||||
@@ -57,6 +57,7 @@ go_library(
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/storage/etcd3/preflight:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/feature:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/flag:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/globalflag:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/webhook:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/client-go/informers:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/client-go/kubernetes:go_default_library",
 | 
			
		||||
 
 | 
			
		||||
@@ -9,6 +9,7 @@ load(
 | 
			
		||||
go_library(
 | 
			
		||||
    name = "go_default_library",
 | 
			
		||||
    srcs = [
 | 
			
		||||
        "globalflags.go",
 | 
			
		||||
        "options.go",
 | 
			
		||||
        "validation.go",
 | 
			
		||||
    ],
 | 
			
		||||
@@ -16,6 +17,7 @@ go_library(
 | 
			
		||||
    deps = [
 | 
			
		||||
        "//pkg/api/legacyscheme:go_default_library",
 | 
			
		||||
        "//pkg/apis/core:go_default_library",
 | 
			
		||||
        "//pkg/cloudprovider/providers:go_default_library",
 | 
			
		||||
        "//pkg/features:go_default_library",
 | 
			
		||||
        "//pkg/kubeapiserver/options:go_default_library",
 | 
			
		||||
        "//pkg/kubelet/client:go_default_library",
 | 
			
		||||
@@ -24,17 +26,23 @@ go_library(
 | 
			
		||||
        "//pkg/serviceaccount:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiextensions-apiserver/pkg/apiserver:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apimachinery/pkg/util/net:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/admission:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/server/options:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/storage/storagebackend:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/feature:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/flag:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/globalflag:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/kube-aggregator/pkg/apiserver/scheme:go_default_library",
 | 
			
		||||
        "//vendor/github.com/spf13/pflag:go_default_library",
 | 
			
		||||
    ],
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
go_test(
 | 
			
		||||
    name = "go_default_test",
 | 
			
		||||
    srcs = ["options_test.go"],
 | 
			
		||||
    srcs = [
 | 
			
		||||
        "globalflags_test.go",
 | 
			
		||||
        "options_test.go",
 | 
			
		||||
    ],
 | 
			
		||||
    embed = [":go_default_library"],
 | 
			
		||||
    deps = [
 | 
			
		||||
        "//pkg/api/legacyscheme:go_default_library",
 | 
			
		||||
@@ -46,6 +54,7 @@ go_test(
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/server/options:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/storage/storagebackend:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/flag:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/pkg/util/globalflag:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/plugin/pkg/audit/buffered:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/apiserver/plugin/pkg/audit/truncate:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/client-go/rest:go_default_library",
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										41
									
								
								cmd/kube-apiserver/app/options/globalflags.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								cmd/kube-apiserver/app/options/globalflags.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,41 @@
 | 
			
		||||
/*
 | 
			
		||||
Copyright 2018 The Kubernetes Authors.
 | 
			
		||||
 | 
			
		||||
Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
you may not use this file except in compliance with the License.
 | 
			
		||||
You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
    http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
See the License for the specific language governing permissions and
 | 
			
		||||
limitations under the License.
 | 
			
		||||
*/
 | 
			
		||||
 | 
			
		||||
package options
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"github.com/spf13/pflag"
 | 
			
		||||
 | 
			
		||||
	"k8s.io/apiserver/pkg/util/globalflag"
 | 
			
		||||
 | 
			
		||||
	// ensure libs have a chance to globally register their flags
 | 
			
		||||
	_ "k8s.io/apiserver/pkg/admission"
 | 
			
		||||
	_ "k8s.io/kubernetes/pkg/cloudprovider/providers"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// AddCustomGlobalFlags explicitly registers flags that internal packages register
 | 
			
		||||
// against the global flagsets from "flag". We do this in order to prevent
 | 
			
		||||
// unwanted flags from leaking into the kube-apiserver's flagset.
 | 
			
		||||
func AddCustomGlobalFlags(fs *pflag.FlagSet) {
 | 
			
		||||
	// Lookup flags in global flag set and re-register the values with our flagset.
 | 
			
		||||
 | 
			
		||||
	// Adds flags from k8s.io/kubernetes/pkg/cloudprovider/providers.
 | 
			
		||||
	globalflag.Register(fs, "cloud-provider-gce-lb-src-cidrs")
 | 
			
		||||
 | 
			
		||||
	// Adds flags from k8s.io/apiserver/pkg/admission.
 | 
			
		||||
	globalflag.Register(fs, "default-not-ready-toleration-seconds")
 | 
			
		||||
	globalflag.Register(fs, "default-unreachable-toleration-seconds")
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										61
									
								
								cmd/kube-apiserver/app/options/globalflags_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								cmd/kube-apiserver/app/options/globalflags_test.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,61 @@
 | 
			
		||||
/*
 | 
			
		||||
Copyright 2018 The Kubernetes Authors.
 | 
			
		||||
 | 
			
		||||
Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
you may not use this file except in compliance with the License.
 | 
			
		||||
You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
    http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
See the License for the specific language governing permissions and
 | 
			
		||||
limitations under the License.
 | 
			
		||||
*/
 | 
			
		||||
 | 
			
		||||
package options
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"flag"
 | 
			
		||||
	"reflect"
 | 
			
		||||
	"sort"
 | 
			
		||||
	"strings"
 | 
			
		||||
	"testing"
 | 
			
		||||
 | 
			
		||||
	"github.com/spf13/pflag"
 | 
			
		||||
 | 
			
		||||
	apiserverflag "k8s.io/apiserver/pkg/util/flag"
 | 
			
		||||
	"k8s.io/apiserver/pkg/util/globalflag"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func TestAddCustomGlobalFlags(t *testing.T) {
 | 
			
		||||
	namedFlagSets := &apiserverflag.NamedFlagSets{}
 | 
			
		||||
 | 
			
		||||
	// Note that we will register all flags (including klog flags) into the same
 | 
			
		||||
	// flag set. This allows us to test against all global flags from
 | 
			
		||||
	// flags.CommandLine.
 | 
			
		||||
	nfs := namedFlagSets.FlagSet("test")
 | 
			
		||||
	globalflag.AddGlobalFlags(nfs, "test-cmd")
 | 
			
		||||
	AddCustomGlobalFlags(nfs)
 | 
			
		||||
 | 
			
		||||
	actualFlag := []string{}
 | 
			
		||||
	nfs.VisitAll(func(flag *pflag.Flag) {
 | 
			
		||||
		actualFlag = append(actualFlag, flag.Name)
 | 
			
		||||
	})
 | 
			
		||||
 | 
			
		||||
	// Get all flags from flags.CommandLine, except flag `test.*`.
 | 
			
		||||
	wantedFlag := []string{"help"}
 | 
			
		||||
	pflag.CommandLine.SetNormalizeFunc(apiserverflag.WordSepNormalizeFunc)
 | 
			
		||||
	pflag.CommandLine.AddGoFlagSet(flag.CommandLine)
 | 
			
		||||
	pflag.VisitAll(func(flag *pflag.Flag) {
 | 
			
		||||
		if !strings.Contains(flag.Name, "test.") {
 | 
			
		||||
			wantedFlag = append(wantedFlag, flag.Name)
 | 
			
		||||
		}
 | 
			
		||||
	})
 | 
			
		||||
	sort.Strings(wantedFlag)
 | 
			
		||||
 | 
			
		||||
	if !reflect.DeepEqual(wantedFlag, actualFlag) {
 | 
			
		||||
		t.Errorf("[Default]: expected %+v, got %+v", wantedFlag, actualFlag)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
@@ -50,6 +50,7 @@ import (
 | 
			
		||||
	serverstorage "k8s.io/apiserver/pkg/server/storage"
 | 
			
		||||
	"k8s.io/apiserver/pkg/storage/etcd3/preflight"
 | 
			
		||||
	apiserverflag "k8s.io/apiserver/pkg/util/flag"
 | 
			
		||||
	"k8s.io/apiserver/pkg/util/globalflag"
 | 
			
		||||
	"k8s.io/apiserver/pkg/util/webhook"
 | 
			
		||||
	clientgoinformers "k8s.io/client-go/informers"
 | 
			
		||||
	clientgoclientset "k8s.io/client-go/kubernetes"
 | 
			
		||||
@@ -117,6 +118,9 @@ cluster's shared state through which all other components interact.`,
 | 
			
		||||
 | 
			
		||||
	fs := cmd.Flags()
 | 
			
		||||
	namedFlagSets := s.Flags()
 | 
			
		||||
	verflag.AddFlags(namedFlagSets.FlagSet("global"))
 | 
			
		||||
	globalflag.AddGlobalFlags(namedFlagSets.FlagSet("global"), cmd.Name())
 | 
			
		||||
	options.AddCustomGlobalFlags(namedFlagSets.FlagSet("generic"))
 | 
			
		||||
	for _, f := range namedFlagSets.FlagSets {
 | 
			
		||||
		fs.AddFlagSet(f)
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user