2017-12-02 19:28:11 +01:00
|
|
|
package kubernetes
|
|
|
|
|
|
|
|
import (
|
2018-02-14 16:56:04 +08:00
|
|
|
corev1 "k8s.io/api/core/v1"
|
|
|
|
extensionsv1beta1 "k8s.io/api/extensions/v1beta1"
|
2017-12-02 19:28:11 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type clientMock struct {
|
2018-02-14 16:56:04 +08:00
|
|
|
ingresses []*extensionsv1beta1.Ingress
|
|
|
|
services []*corev1.Service
|
|
|
|
secrets []*corev1.Secret
|
|
|
|
endpoints []*corev1.Endpoints
|
2017-12-02 19:28:11 +01:00
|
|
|
watchChan chan interface{}
|
|
|
|
|
2018-05-18 06:12:03 -06:00
|
|
|
apiServiceError error
|
|
|
|
apiSecretError error
|
|
|
|
apiEndpointsError error
|
|
|
|
apiIngressStatusError error
|
2017-12-02 19:28:11 +01:00
|
|
|
}
|
|
|
|
|
2018-02-14 16:56:04 +08:00
|
|
|
func (c clientMock) GetIngresses() []*extensionsv1beta1.Ingress {
|
2017-12-02 19:28:11 +01:00
|
|
|
return c.ingresses
|
|
|
|
}
|
|
|
|
|
2018-02-14 16:56:04 +08:00
|
|
|
func (c clientMock) GetService(namespace, name string) (*corev1.Service, bool, error) {
|
2017-12-02 19:28:11 +01:00
|
|
|
if c.apiServiceError != nil {
|
|
|
|
return nil, false, c.apiServiceError
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, service := range c.services {
|
|
|
|
if service.Namespace == namespace && service.Name == name {
|
|
|
|
return service, true, nil
|
|
|
|
}
|
|
|
|
}
|
2018-05-18 06:12:03 -06:00
|
|
|
return nil, false, c.apiServiceError
|
2017-12-02 19:28:11 +01:00
|
|
|
}
|
|
|
|
|
2018-02-14 16:56:04 +08:00
|
|
|
func (c clientMock) GetEndpoints(namespace, name string) (*corev1.Endpoints, bool, error) {
|
2017-12-02 19:28:11 +01:00
|
|
|
if c.apiEndpointsError != nil {
|
|
|
|
return nil, false, c.apiEndpointsError
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, endpoints := range c.endpoints {
|
|
|
|
if endpoints.Namespace == namespace && endpoints.Name == name {
|
|
|
|
return endpoints, true, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-14 16:56:04 +08:00
|
|
|
return &corev1.Endpoints{}, false, nil
|
2017-12-02 19:28:11 +01:00
|
|
|
}
|
|
|
|
|
2018-02-14 16:56:04 +08:00
|
|
|
func (c clientMock) GetSecret(namespace, name string) (*corev1.Secret, bool, error) {
|
2017-12-02 19:28:11 +01:00
|
|
|
if c.apiSecretError != nil {
|
|
|
|
return nil, false, c.apiSecretError
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, secret := range c.secrets {
|
|
|
|
if secret.Namespace == namespace && secret.Name == name {
|
|
|
|
return secret, true, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil, false, nil
|
|
|
|
}
|
|
|
|
|
2018-04-12 11:14:05 +02:00
|
|
|
func (c clientMock) WatchAll(namespaces Namespaces, stopCh <-chan struct{}) (<-chan interface{}, error) {
|
2017-12-02 19:28:11 +01:00
|
|
|
return c.watchChan, nil
|
|
|
|
}
|
2018-05-18 06:12:03 -06:00
|
|
|
|
|
|
|
func (c clientMock) UpdateIngressStatus(namespace, name, ip, hostname string) error {
|
|
|
|
return c.apiIngressStatusError
|
|
|
|
}
|