
* added license templates for go, bash & yaml in tools dir * added a script that will add license information for all missing files. Type: go, yaml, yml, sh * skip adding license for all files within testdata * Syntax: > ./tools/add_license.sh * Skip license for manifests folder * Added one extra line after licene for yaml files * Added License after Hashbang for bash. * Add an extra line after hashbang and before license * Updated the go template to use multiline comments New Files: 1. tools/add_license.sh 2. tools/license_go.txt 3. tools/license_yaml.txt 4. tools/license_bash.txt Change-Id: Ia4da5b261e7cd518d446896b72c810421877472a Realtes-To:#147
77 lines
2.5 KiB
Go
77 lines
2.5 KiB
Go
/*
|
|
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
|
|
|
|
https://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 fake
|
|
|
|
import (
|
|
"k8s.io/client-go/dynamic"
|
|
"k8s.io/client-go/kubernetes"
|
|
|
|
"opendev.org/airship/airshipctl/pkg/k8s/client"
|
|
"opendev.org/airship/airshipctl/pkg/k8s/kubectl"
|
|
)
|
|
|
|
// Client is an implementation of client.Interface meant for testing purposes.
|
|
// Its member methods are intended to be implemented on a case-by-case basis
|
|
// per test. Examples of implementations can be found with each interface
|
|
// method.
|
|
type Client struct {
|
|
MockClientSet func() kubernetes.Interface
|
|
MockDynamicClient func() dynamic.Interface
|
|
MockKubectl func() kubectl.Interface
|
|
}
|
|
|
|
var _ client.Interface = &Client{}
|
|
|
|
// ClientSet is used to get a mocked implementation of a kubernetes clientset.
|
|
// To initialize the mocked clientset to be returned, the MockClientSet method
|
|
// must be implemented, ideally returning a k8s.io/client-go/kubernetes/fake.Clientset.
|
|
//
|
|
// Example:
|
|
//
|
|
// testClient := fake.Client {
|
|
// MockClientSet: func() kubernetes.Interface {
|
|
// return kubernetes_fake.NewSimpleClientset()
|
|
// },
|
|
// }
|
|
func (c Client) ClientSet() kubernetes.Interface {
|
|
return c.MockClientSet()
|
|
}
|
|
|
|
// DynamicClient is used to get a mocked implementation of a dynamic client.
|
|
// To initialize the mocked client to be returned, the MockDynamicClient method
|
|
// must be implemented, ideally returning a k8s.io/client-go/dynamic/fake.FakeDynamicClient.
|
|
//
|
|
// Example:
|
|
// Here, scheme is a k8s.io/apimachinery/pkg/runtime.Scheme, possibly created
|
|
// via runtime.NewScheme()
|
|
//
|
|
// testClient := fake.Client {
|
|
// MockDynamicClient: func() dynamic.Interface {
|
|
// return dynamic_fake.NewSimpleDynamicClient(scheme)
|
|
// },
|
|
// }
|
|
func (c Client) DynamicClient() dynamic.Interface {
|
|
return c.MockDynamicClient()
|
|
}
|
|
|
|
// Kubectl is used to get a mocked implementation of a Kubectl client.
|
|
// To initialize the mocked client to be returned, the MockKubectl method
|
|
// must be implemented.
|
|
//
|
|
// Example: TODO(howell)
|
|
func (c Client) Kubectl() kubectl.Interface {
|
|
return c.MockKubectl()
|
|
}
|