ingress-nginx-helm/controllers/gce/backends/fakes.go

140 lines
4.1 KiB
Go
Raw Normal View History

2016-02-22 00:13:08 +00:00
/*
Copyright 2015 The Kubernetes Authors.
2016-02-22 00:13:08 +00:00
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 backends
import (
"fmt"
2016-11-11 03:14:20 +00:00
2016-02-22 00:13:08 +00:00
compute "google.golang.org/api/compute/v1"
api_v1 "k8s.io/client-go/pkg/api/v1"
2017-04-01 14:38:58 +00:00
"k8s.io/client-go/tools/cache"
2016-11-10 23:31:49 +00:00
"k8s.io/ingress/controllers/gce/utils"
2016-02-22 00:13:08 +00:00
)
// NewFakeBackendServices creates a new fake backend services manager.
2017-02-09 01:23:15 +00:00
func NewFakeBackendServices(ef func(op int, be *compute.BackendService) error) *FakeBackendServices {
2016-02-22 00:13:08 +00:00
return &FakeBackendServices{
2017-02-09 01:23:15 +00:00
errFunc: ef,
2016-11-11 03:14:20 +00:00
backendServices: cache.NewStore(func(obj interface{}) (string, error) {
svc := obj.(*compute.BackendService)
return svc.Name, nil
}),
2016-02-22 00:13:08 +00:00
}
}
// FakeBackendServices fakes out GCE backend services.
type FakeBackendServices struct {
2016-11-11 03:14:20 +00:00
backendServices cache.Store
2016-02-22 00:13:08 +00:00
calls []int
2017-02-09 01:23:15 +00:00
errFunc func(op int, be *compute.BackendService) error
2016-02-22 00:13:08 +00:00
}
// GetBackendService fakes getting a backend service from the cloud.
func (f *FakeBackendServices) GetBackendService(name string) (*compute.BackendService, error) {
f.calls = append(f.calls, utils.Get)
2016-11-11 03:14:20 +00:00
obj, exists, err := f.backendServices.GetByKey(name)
if !exists {
return nil, fmt.Errorf("backend service %v not found", name)
2016-11-11 03:14:20 +00:00
}
if err != nil {
return nil, err
}
svc := obj.(*compute.BackendService)
if name == svc.Name {
return svc, nil
2016-02-22 00:13:08 +00:00
}
return nil, fmt.Errorf("backend service %v not found", name)
2016-02-22 00:13:08 +00:00
}
// CreateBackendService fakes backend service creation.
func (f *FakeBackendServices) CreateBackendService(be *compute.BackendService) error {
2017-02-09 01:23:15 +00:00
if f.errFunc != nil {
if err := f.errFunc(utils.Create, be); err != nil {
return err
}
}
2016-02-22 00:13:08 +00:00
f.calls = append(f.calls, utils.Create)
be.SelfLink = be.Name
2016-11-11 03:14:20 +00:00
return f.backendServices.Update(be)
2016-02-22 00:13:08 +00:00
}
// DeleteBackendService fakes backend service deletion.
func (f *FakeBackendServices) DeleteBackendService(name string) error {
f.calls = append(f.calls, utils.Delete)
2016-11-11 03:14:20 +00:00
svc, exists, err := f.backendServices.GetByKey(name)
if !exists {
return fmt.Errorf("backend service %v not found", name)
2016-11-11 03:14:20 +00:00
}
if err != nil {
return err
2016-02-22 00:13:08 +00:00
}
2016-11-11 03:14:20 +00:00
return f.backendServices.Delete(svc)
2016-02-22 00:13:08 +00:00
}
// ListBackendServices fakes backend service listing.
func (f *FakeBackendServices) ListBackendServices() (*compute.BackendServiceList, error) {
2016-11-11 03:14:20 +00:00
var svcs []*compute.BackendService
for _, s := range f.backendServices.List() {
svc := s.(*compute.BackendService)
svcs = append(svcs, svc)
}
return &compute.BackendServiceList{Items: svcs}, nil
2016-02-22 00:13:08 +00:00
}
// UpdateBackendService fakes updating a backend service.
func (f *FakeBackendServices) UpdateBackendService(be *compute.BackendService) error {
f.calls = append(f.calls, utils.Update)
2016-11-11 03:14:20 +00:00
return f.backendServices.Update(be)
2016-02-22 00:13:08 +00:00
}
// GetHealth fakes getting backend service health.
func (f *FakeBackendServices) GetHealth(name, instanceGroupLink string) (*compute.BackendServiceGroupHealth, error) {
be, err := f.GetBackendService(name)
if err != nil {
return nil, err
}
states := []*compute.HealthStatus{
{
HealthState: "HEALTHY",
IpAddress: "",
Port: be.Port,
},
}
return &compute.BackendServiceGroupHealth{
HealthStatus: states}, nil
}
// FakeProbeProvider implements the probeProvider interface for tests.
type FakeProbeProvider struct {
probes map[ServicePort]*api_v1.Probe
}
2017-04-20 19:48:14 +00:00
// NewFakeProbeProvider returns a struct which satisfies probeProvider interface
func NewFakeProbeProvider(probes map[ServicePort]*api_v1.Probe) *FakeProbeProvider {
return &FakeProbeProvider{probes}
}
// GetProbe returns the probe for a given nodePort
func (pp *FakeProbeProvider) GetProbe(port ServicePort) (*api_v1.Probe, error) {
if probe, exists := pp.probes[port]; exists && probe.HTTPGet != nil {
return probe, nil
}
return nil, nil
}