add fake factories for test

This commit is contained in:
AdoHe 2016-10-13 08:11:07 +08:00
parent 593d8e0d7c
commit dfae1a27c2

View File

@ -28,6 +28,10 @@ import (
"testing" "testing"
"time" "time"
"github.com/emicklei/go-restful/swagger"
"github.com/spf13/cobra"
"github.com/spf13/pflag"
"k8s.io/kubernetes/pkg/api" "k8s.io/kubernetes/pkg/api"
"k8s.io/kubernetes/pkg/api/meta" "k8s.io/kubernetes/pkg/api/meta"
"k8s.io/kubernetes/pkg/api/testapi" "k8s.io/kubernetes/pkg/api/testapi"
@ -210,7 +214,12 @@ type testFactory struct {
Err error Err error
} }
func NewTestFactory() (*cmdutil.Factory, *testFactory, runtime.Codec, runtime.NegotiatedSerializer) { type fakeFactory struct {
tf *testFactory
Codec runtime.Codec
}
func NewTestFactory() (cmdutil.Factory, *testFactory, runtime.Codec, runtime.NegotiatedSerializer) {
scheme, mapper, codec := newExternalScheme() scheme, mapper, codec := newExternalScheme()
t := &testFactory{ t := &testFactory{
Validator: validation.NullSchema{}, Validator: validation.NullSchema{},
@ -220,10 +229,19 @@ func NewTestFactory() (*cmdutil.Factory, *testFactory, runtime.Codec, runtime.Ne
negotiatedSerializer := serializer.NegotiatedSerializerWrapper( negotiatedSerializer := serializer.NegotiatedSerializerWrapper(
runtime.SerializerInfo{Serializer: codec}, runtime.SerializerInfo{Serializer: codec},
runtime.StreamSerializerInfo{}) runtime.StreamSerializerInfo{})
return &cmdutil.Factory{ return &fakeFactory{
Object: func() (meta.RESTMapper, runtime.ObjectTyper) { tf: t,
Codec: codec,
}, t, codec, negotiatedSerializer
}
func (f *fakeFactory) FlagSet() *pflag.FlagSet {
return nil
}
func (f *fakeFactory) Object() (meta.RESTMapper, runtime.ObjectTyper) {
priorityRESTMapper := meta.PriorityRESTMapper{ priorityRESTMapper := meta.PriorityRESTMapper{
Delegate: t.Mapper, Delegate: f.tf.Mapper,
ResourcePriority: []unversioned.GroupVersionResource{ ResourcePriority: []unversioned.GroupVersionResource{
{Group: meta.AnyGroup, Version: "v1", Resource: meta.AnyResource}, {Group: meta.AnyGroup, Version: "v1", Resource: meta.AnyResource},
}, },
@ -231,41 +249,176 @@ func NewTestFactory() (*cmdutil.Factory, *testFactory, runtime.Codec, runtime.Ne
{Group: meta.AnyGroup, Version: "v1", Kind: meta.AnyKind}, {Group: meta.AnyGroup, Version: "v1", Kind: meta.AnyKind},
}, },
} }
return priorityRESTMapper, t.Typer return priorityRESTMapper, f.tf.Typer
},
ClientForMapping: func(*meta.RESTMapping) (resource.RESTClient, error) {
return t.Client, t.Err
},
Decoder: func(bool) runtime.Decoder {
return codec
},
JSONEncoder: func() runtime.Encoder {
return codec
},
Describer: func(*meta.RESTMapping) (kubectl.Describer, error) {
return t.Describer, t.Err
},
Printer: func(mapping *meta.RESTMapping, options kubectl.PrintOptions) (kubectl.ResourcePrinter, error) {
return t.Printer, t.Err
},
Validator: func(validate bool, cacheDir string) (validation.Schema, error) {
return t.Validator, t.Err
},
DefaultNamespace: func() (string, bool, error) {
return t.Namespace, false, t.Err
},
ClientConfig: func() (*restclient.Config, error) {
return t.ClientConfig, t.Err
},
}, t, codec, negotiatedSerializer
} }
func NewMixedFactory(apiClient resource.RESTClient) (*cmdutil.Factory, *testFactory, runtime.Codec) { func (f *fakeFactory) UnstructuredObject() (meta.RESTMapper, runtime.ObjectTyper, error) {
f, t, c, _ := NewTestFactory() return nil, nil, nil
}
func (f *fakeFactory) Decoder(bool) runtime.Decoder {
return f.Codec
}
func (f *fakeFactory) JSONEncoder() runtime.Encoder {
return f.Codec
}
func (f *fakeFactory) RESTClient() (*restclient.RESTClient, error) {
return nil, nil
}
func (f *fakeFactory) ClientSet() (*internalclientset.Clientset, error) {
return nil, nil
}
func (f *fakeFactory) ClientConfig() (*restclient.Config, error) {
return f.tf.ClientConfig, f.tf.Err
}
func (f *fakeFactory) ClientForMapping(*meta.RESTMapping) (resource.RESTClient, error) {
return f.tf.Client, f.tf.Err
}
func (f *fakeFactory) UnstructuredClientForMapping(*meta.RESTMapping) (resource.RESTClient, error) {
return nil, nil
}
func (f *fakeFactory) Describer(*meta.RESTMapping) (kubectl.Describer, error) {
return f.tf.Describer, f.tf.Err
}
func (f *fakeFactory) Printer(mapping *meta.RESTMapping, options kubectl.PrintOptions) (kubectl.ResourcePrinter, error) {
return f.tf.Printer, f.tf.Err
}
func (f *fakeFactory) Scaler(*meta.RESTMapping) (kubectl.Scaler, error) {
return nil, nil
}
func (f *fakeFactory) Reaper(*meta.RESTMapping) (kubectl.Reaper, error) {
return nil, nil
}
func (f *fakeFactory) HistoryViewer(*meta.RESTMapping) (kubectl.HistoryViewer, error) {
return nil, nil
}
func (f *fakeFactory) Rollbacker(*meta.RESTMapping) (kubectl.Rollbacker, error) {
return nil, nil
}
func (f *fakeFactory) StatusViewer(*meta.RESTMapping) (kubectl.StatusViewer, error) {
return nil, nil
}
func (f *fakeFactory) MapBasedSelectorForObject(runtime.Object) (string, error) {
return "", nil
}
func (f *fakeFactory) PortsForObject(runtime.Object) ([]string, error) {
return nil, nil
}
func (f *fakeFactory) ProtocolsForObject(runtime.Object) (map[string]string, error) {
return nil, nil
}
func (f *fakeFactory) LabelsForObject(runtime.Object) (map[string]string, error) {
return nil, nil
}
func (f *fakeFactory) LogsForObject(object, options runtime.Object) (*restclient.Request, error) {
return nil, nil
}
func (f *fakeFactory) PauseObject(runtime.Object) (bool, error) {
return false, nil
}
func (f *fakeFactory) ResumeObject(runtime.Object) (bool, error) {
return false, nil
}
func (f *fakeFactory) Validator(validate bool, cacheDir string) (validation.Schema, error) {
return f.tf.Validator, f.tf.Err
}
func (f *fakeFactory) SwaggerSchema(unversioned.GroupVersionKind) (*swagger.ApiDeclaration, error) {
return nil, nil
}
func (f *fakeFactory) DefaultNamespace() (string, bool, error) {
return f.tf.Namespace, false, f.tf.Err
}
func (f *fakeFactory) Generators(string) map[string]kubectl.Generator {
return nil
}
func (f *fakeFactory) CanBeExposed(unversioned.GroupKind) error {
return nil
}
func (f *fakeFactory) CanBeAutoscaled(unversioned.GroupKind) error {
return nil
}
func (f *fakeFactory) AttachablePodForObject(ob runtime.Object) (*api.Pod, error) {
return nil, nil
}
func (f *fakeFactory) UpdatePodSpecForObject(obj runtime.Object, fn func(*api.PodSpec) error) (bool, error) {
return false, nil
}
func (f *fakeFactory) EditorEnvs() []string {
return nil
}
func (f *fakeFactory) PrintObjectSpecificMessage(obj runtime.Object, out io.Writer) {
}
func (f *fakeFactory) Command() string {
return ""
}
func (f *fakeFactory) BindFlags(flags *pflag.FlagSet) {
}
func (f *fakeFactory) BindExternalFlags(flags *pflag.FlagSet) {
}
func (f *fakeFactory) PrintObject(cmd *cobra.Command, mapper meta.RESTMapper, obj runtime.Object, out io.Writer) error {
return nil
}
func (f *fakeFactory) PrinterForMapping(cmd *cobra.Command, mapping *meta.RESTMapping, withNamespace bool) (kubectl.ResourcePrinter, error) {
return f.tf.Printer, f.tf.Err
}
func (f *fakeFactory) NewBuilder() *resource.Builder {
return nil
}
func (f *fakeFactory) DefaultResourceFilterOptions(cmd *cobra.Command, withNamespace bool) *kubectl.PrintOptions {
return &kubectl.PrintOptions{}
}
func (f *fakeFactory) DefaultResourceFilterFunc() kubectl.Filters {
return nil
}
type fakeMixedFactory struct {
cmdutil.Factory
tf *testFactory
apiClient resource.RESTClient
}
func (f *fakeMixedFactory) Object() (meta.RESTMapper, runtime.ObjectTyper) {
var multiRESTMapper meta.MultiRESTMapper var multiRESTMapper meta.MultiRESTMapper
multiRESTMapper = append(multiRESTMapper, t.Mapper) multiRESTMapper = append(multiRESTMapper, f.tf.Mapper)
multiRESTMapper = append(multiRESTMapper, testapi.Default.RESTMapper()) multiRESTMapper = append(multiRESTMapper, testapi.Default.RESTMapper())
f.Object = func() (meta.RESTMapper, runtime.ObjectTyper) {
priorityRESTMapper := meta.PriorityRESTMapper{ priorityRESTMapper := meta.PriorityRESTMapper{
Delegate: multiRESTMapper, Delegate: multiRESTMapper,
ResourcePriority: []unversioned.GroupVersionResource{ ResourcePriority: []unversioned.GroupVersionResource{
@ -275,86 +428,95 @@ func NewMixedFactory(apiClient resource.RESTClient) (*cmdutil.Factory, *testFact
{Group: meta.AnyGroup, Version: "v1", Kind: meta.AnyKind}, {Group: meta.AnyGroup, Version: "v1", Kind: meta.AnyKind},
}, },
} }
return priorityRESTMapper, runtime.MultiObjectTyper{t.Typer, api.Scheme} return priorityRESTMapper, runtime.MultiObjectTyper{f.tf.Typer, api.Scheme}
} }
f.ClientForMapping = func(m *meta.RESTMapping) (resource.RESTClient, error) {
func (f *fakeMixedFactory) ClientForMapping(m *meta.RESTMapping) (resource.RESTClient, error) {
if m.ObjectConvertor == api.Scheme { if m.ObjectConvertor == api.Scheme {
return apiClient, t.Err return f.apiClient, f.tf.Err
} }
return t.Client, t.Err return f.tf.Client, f.tf.Err
}
return f, t, c
} }
func NewAPIFactory() (*cmdutil.Factory, *testFactory, runtime.Codec, runtime.NegotiatedSerializer) { func NewMixedFactory(apiClient resource.RESTClient) (cmdutil.Factory, *testFactory, runtime.Codec) {
t := &testFactory{ f, t, c, _ := NewTestFactory()
Validator: validation.NullSchema{}, return &fakeMixedFactory{
Factory: f,
tf: t,
apiClient: apiClient,
}, t, c
} }
f := &cmdutil.Factory{ type fakeAPIFactory struct {
Object: func() (meta.RESTMapper, runtime.ObjectTyper) { cmdutil.Factory
tf *testFactory
}
func (f *fakeAPIFactory) Object() (meta.RESTMapper, runtime.ObjectTyper) {
return testapi.Default.RESTMapper(), api.Scheme return testapi.Default.RESTMapper(), api.Scheme
}, }
UnstructuredObject: func() (meta.RESTMapper, runtime.ObjectTyper, error) {
func (f *fakeAPIFactory) UnstructuredObject() (meta.RESTMapper, runtime.ObjectTyper, error) {
groupResources := testDynamicResources() groupResources := testDynamicResources()
mapper := discovery.NewRESTMapper(groupResources, meta.InterfacesForUnstructured) mapper := discovery.NewRESTMapper(groupResources, meta.InterfacesForUnstructured)
typer := discovery.NewUnstructuredObjectTyper(groupResources) typer := discovery.NewUnstructuredObjectTyper(groupResources)
return cmdutil.NewShortcutExpander(mapper, nil), typer, nil return cmdutil.NewShortcutExpander(mapper, nil), typer, nil
}, }
ClientSet: func() (*internalclientset.Clientset, error) {
func (f *fakeAPIFactory) Decoder(bool) runtime.Decoder {
return testapi.Default.Codec()
}
func (f *fakeAPIFactory) JSONEncoder() runtime.Encoder {
return testapi.Default.Codec()
}
func (f *fakeAPIFactory) ClientSet() (*internalclientset.Clientset, error) {
// Swap out the HTTP client out of the client with the fake's version. // Swap out the HTTP client out of the client with the fake's version.
fakeClient := t.Client.(*fake.RESTClient) fakeClient := f.tf.Client.(*fake.RESTClient)
restClient, err := restclient.RESTClientFor(t.ClientConfig) restClient, err := restclient.RESTClientFor(f.tf.ClientConfig)
if err != nil { if err != nil {
panic(err) panic(err)
} }
restClient.Client = fakeClient.Client restClient.Client = fakeClient.Client
return internalclientset.New(restClient), t.Err return internalclientset.New(restClient), f.tf.Err
}, }
RESTClient: func() (*restclient.RESTClient, error) {
func (f *fakeAPIFactory) RESTClient() (*restclient.RESTClient, error) {
// Swap out the HTTP client out of the client with the fake's version. // Swap out the HTTP client out of the client with the fake's version.
fakeClient := t.Client.(*fake.RESTClient) fakeClient := f.tf.Client.(*fake.RESTClient)
restClient, err := restclient.RESTClientFor(t.ClientConfig) restClient, err := restclient.RESTClientFor(f.tf.ClientConfig)
if err != nil { if err != nil {
panic(err) panic(err)
} }
restClient.Client = fakeClient.Client restClient.Client = fakeClient.Client
return restClient, t.Err return restClient, f.tf.Err
}, }
ClientForMapping: func(*meta.RESTMapping) (resource.RESTClient, error) {
return t.Client, t.Err func (f *fakeAPIFactory) ClientConfig() (*restclient.Config, error) {
}, return f.tf.ClientConfig, f.tf.Err
UnstructuredClientForMapping: func(*meta.RESTMapping) (resource.RESTClient, error) { }
return t.Client, t.Err
}, func (f *fakeAPIFactory) ClientForMapping(*meta.RESTMapping) (resource.RESTClient, error) {
Decoder: func(bool) runtime.Decoder { return f.tf.Client, f.tf.Err
return testapi.Default.Codec() }
},
JSONEncoder: func() runtime.Encoder { func (f *fakeAPIFactory) UnstructuredClientForMapping(*meta.RESTMapping) (resource.RESTClient, error) {
return testapi.Default.Codec() return f.tf.Client, f.tf.Err
}, }
Describer: func(*meta.RESTMapping) (kubectl.Describer, error) {
return t.Describer, t.Err func (f *fakeAPIFactory) Describer(*meta.RESTMapping) (kubectl.Describer, error) {
}, return f.tf.Describer, f.tf.Err
Printer: func(mapping *meta.RESTMapping, options kubectl.PrintOptions) (kubectl.ResourcePrinter, error) { }
return t.Printer, t.Err
}, func (f *fakeAPIFactory) Printer(mapping *meta.RESTMapping, options kubectl.PrintOptions) (kubectl.ResourcePrinter, error) {
Validator: func(validate bool, cacheDir string) (validation.Schema, error) { return f.tf.Printer, f.tf.Err
return t.Validator, t.Err }
},
DefaultNamespace: func() (string, bool, error) { func (f *fakeAPIFactory) LogsForObject(object, options runtime.Object) (*restclient.Request, error) {
return t.Namespace, false, t.Err fakeClient := f.tf.Client.(*fake.RESTClient)
}, c := client.NewOrDie(f.tf.ClientConfig)
ClientConfig: func() (*restclient.Config, error) {
return t.ClientConfig, t.Err
},
Generators: func(cmdName string) map[string]kubectl.Generator {
return cmdutil.DefaultGenerators(cmdName)
},
LogsForObject: func(object, options runtime.Object) (*restclient.Request, error) {
fakeClient := t.Client.(*fake.RESTClient)
c := client.NewOrDie(t.ClientConfig)
c.Client = fakeClient.Client c.Client = fakeClient.Client
switch t := object.(type) { switch t := object.(type) {
@ -363,7 +525,7 @@ func NewAPIFactory() (*cmdutil.Factory, *testFactory, runtime.Codec, runtime.Neg
if !ok { if !ok {
return nil, errors.New("provided options object is not a PodLogOptions") return nil, errors.New("provided options object is not a PodLogOptions")
} }
return c.Pods(t.Namespace).GetLogs(t.Name, opts), nil return c.Pods(f.tf.Namespace).GetLogs(t.Name, opts), nil
default: default:
fqKinds, _, err := api.Scheme.ObjectKinds(object) fqKinds, _, err := api.Scheme.ObjectKinds(object)
if err != nil { if err != nil {
@ -371,16 +533,57 @@ func NewAPIFactory() (*cmdutil.Factory, *testFactory, runtime.Codec, runtime.Neg
} }
return nil, fmt.Errorf("cannot get the logs from %v", fqKinds[0]) return nil, fmt.Errorf("cannot get the logs from %v", fqKinds[0])
} }
}, }
func (f *fakeAPIFactory) Validator(validate bool, cacheDir string) (validation.Schema, error) {
return f.tf.Validator, f.tf.Err
}
func (f *fakeAPIFactory) DefaultNamespace() (string, bool, error) {
return f.tf.Namespace, false, f.tf.Err
}
func (f *fakeAPIFactory) Generators(cmdName string) map[string]kubectl.Generator {
return cmdutil.DefaultGenerators(cmdName)
}
func (f *fakeAPIFactory) PrintObject(cmd *cobra.Command, mapper meta.RESTMapper, obj runtime.Object, out io.Writer) error {
gvks, _, err := api.Scheme.ObjectKinds(obj)
if err != nil {
return err
}
mapping, err := mapper.RESTMapping(gvks[0].GroupKind())
if err != nil {
return err
}
printer, err := f.PrinterForMapping(cmd, mapping, false)
if err != nil {
return err
}
return printer.PrintObj(obj, out)
}
func (f *fakeAPIFactory) PrinterForMapping(cmd *cobra.Command, mapping *meta.RESTMapping, withNamespace bool) (kubectl.ResourcePrinter, error) {
return f.tf.Printer, f.tf.Err
}
func (f *fakeAPIFactory) NewBuilder() *resource.Builder {
mapper, typer := f.Object()
return resource.NewBuilder(mapper, typer, resource.ClientMapperFunc(f.ClientForMapping), f.Decoder(true))
}
func NewAPIFactory() (cmdutil.Factory, *testFactory, runtime.Codec, runtime.NegotiatedSerializer) {
t := &testFactory{
Validator: validation.NullSchema{},
} }
rf := cmdutil.NewFactory(nil) rf := cmdutil.NewFactory(nil)
f.MapBasedSelectorForObject = rf.MapBasedSelectorForObject return &fakeAPIFactory{
f.PortsForObject = rf.PortsForObject Factory: rf,
f.ProtocolsForObject = rf.ProtocolsForObject tf: t,
f.LabelsForObject = rf.LabelsForObject }, t, testapi.Default.Codec(), testapi.Default.NegotiatedSerializer()
f.CanBeExposed = rf.CanBeExposed
f.PrintObjectSpecificMessage = rf.PrintObjectSpecificMessage
return f, t, testapi.Default.Codec(), testapi.Default.NegotiatedSerializer()
} }
func objBody(codec runtime.Codec, obj runtime.Object) io.ReadCloser { func objBody(codec runtime.Codec, obj runtime.Object) io.ReadCloser {