mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-01 15:58:37 +00:00
make kubectl factory flag binding optional
This commit is contained in:
parent
6ff26d924c
commit
500bb3a7fa
@ -30,7 +30,7 @@ func main() {
|
|||||||
// Set environment variables used by kubectl so the output is consistent,
|
// Set environment variables used by kubectl so the output is consistent,
|
||||||
// regardless of where we run.
|
// regardless of where we run.
|
||||||
os.Setenv("HOME", "/home/username")
|
os.Setenv("HOME", "/home/username")
|
||||||
kubectl := cmd.NewFactory().NewKubectlCommand(out)
|
kubectl := cmd.NewFactory(nil).NewKubectlCommand(out)
|
||||||
fmt.Fprintf(out, "## %s\n\n", kubectl.Name())
|
fmt.Fprintf(out, "## %s\n\n", kubectl.Name())
|
||||||
fmt.Fprintf(out, "%s\n\n", kubectl.Short)
|
fmt.Fprintf(out, "%s\n\n", kubectl.Short)
|
||||||
fmt.Fprintln(out, "### Commands\n")
|
fmt.Fprintln(out, "### Commands\n")
|
||||||
|
@ -23,7 +23,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
cmd := cmd.NewFactory().NewKubectlCommand(os.Stdout)
|
cmd := cmd.NewFactory(nil).NewKubectlCommand(os.Stdout)
|
||||||
if err := cmd.Execute(); err != nil {
|
if err := cmd.Execute(); err != nil {
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
@ -69,11 +69,18 @@ type Factory struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// NewFactory creates a factory with the default Kubernetes resources defined
|
// NewFactory creates a factory with the default Kubernetes resources defined
|
||||||
func NewFactory() *Factory {
|
// if optionalClientConfig is nil, then flags will be bound to a new clientcmd.ClientConfig.
|
||||||
|
// if optionalClientConfig is not nil, then this factory will make use of it.
|
||||||
|
func NewFactory(optionalClientConfig clientcmd.ClientConfig) *Factory {
|
||||||
mapper := kubectl.ShortcutExpander{latest.RESTMapper}
|
mapper := kubectl.ShortcutExpander{latest.RESTMapper}
|
||||||
|
|
||||||
flags := pflag.NewFlagSet("", pflag.ContinueOnError)
|
flags := pflag.NewFlagSet("", pflag.ContinueOnError)
|
||||||
clientConfig := DefaultClientConfig(flags)
|
|
||||||
|
clientConfig := optionalClientConfig
|
||||||
|
if optionalClientConfig == nil {
|
||||||
|
clientConfig = DefaultClientConfig(flags)
|
||||||
|
}
|
||||||
|
|
||||||
clients := &clientCache{
|
clients := &clientCache{
|
||||||
clients: make(map[string]*client.Client),
|
clients: make(map[string]*client.Client),
|
||||||
loader: clientConfig,
|
loader: clientConfig,
|
||||||
|
41
pkg/kubectl/cmd/factory_test.go
Normal file
41
pkg/kubectl/cmd/factory_test.go
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2014 Google Inc. All rights reserved.
|
||||||
|
|
||||||
|
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 cmd
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/client/clientcmd"
|
||||||
|
clientcmdapi "github.com/GoogleCloudPlatform/kubernetes/pkg/client/clientcmd/api"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestNewFactoryDefaultFlagBindings(t *testing.T) {
|
||||||
|
factory := NewFactory(nil)
|
||||||
|
|
||||||
|
if !factory.flags.HasFlags() {
|
||||||
|
t.Errorf("Expected flags, but didn't get any")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestNewFactoryNoFlagBindings(t *testing.T) {
|
||||||
|
clientConfig := clientcmd.NewDefaultClientConfig(*clientcmdapi.NewConfig(), &clientcmd.ConfigOverrides{})
|
||||||
|
factory := NewFactory(clientConfig)
|
||||||
|
|
||||||
|
if factory.flags.HasFlags() {
|
||||||
|
t.Errorf("Expected zero flags, but got %v", factory.flags)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user