mirror of
https://github.com/kubernetes-sigs/external-dns.git
synced 2025-08-06 01:26:59 +02:00
* adds tests for shouldUpdateProviderSpecific Signed-off-by: Raffaele Di Fazio <difazio.raffaele@gmail.com> * move AWS health to where it belongs Signed-off-by: Raffaele Di Fazio <difazio.raffaele@gmail.com> * add test that breaks things Signed-off-by: Raffaele Di Fazio <difazio.raffaele@gmail.com> * adds adjustendpoints method Signed-off-by: Raffaele Di Fazio <raffo@github.com> * fix controller Signed-off-by: Raffaele Di Fazio <raffo@github.com> * actually pass the provider where needed Signed-off-by: Raffaele Di Fazio <raffo@github.com> * OMG goland do your go fmt thing Signed-off-by: Raffaele Di Fazio <raffo@github.com> * use registry as proxy Signed-off-by: Raffaele Di Fazio <raffo@github.com> * make linter happy Signed-off-by: Raffaele Di Fazio <raffo@github.com> * change AdjustEndpoints signature Signed-off-by: Raffaele Di Fazio <raffo@github.com> * fix typo Signed-off-by: Raffaele Di Fazio <raffo@github.com> * actually use adjusted endpoints Signed-off-by: Raffaele Di Fazio <raffo@github.com> * revert cloudflare change Signed-off-by: Raffaele Di Fazio <raffo@github.com> * Update provider/cloudflare/cloudflare.go Co-authored-by: Nick Jüttner <nick@juni.io> Co-authored-by: Nick Jüttner <nick@juni.io>
162 lines
5.8 KiB
Go
162 lines
5.8 KiB
Go
/*
|
|
Copyright 2017 The Kubernetes Authors.
|
|
|
|
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 source
|
|
|
|
import (
|
|
"errors"
|
|
"testing"
|
|
|
|
cfclient "github.com/cloudfoundry-community/go-cfclient"
|
|
openshift "github.com/openshift/client-go/route/clientset/versioned"
|
|
"github.com/stretchr/testify/mock"
|
|
"github.com/stretchr/testify/suite"
|
|
istioclient "istio.io/client-go/pkg/clientset/versioned"
|
|
"k8s.io/client-go/dynamic"
|
|
"k8s.io/client-go/kubernetes"
|
|
fakeKube "k8s.io/client-go/kubernetes/fake"
|
|
)
|
|
|
|
type MockClientGenerator struct {
|
|
mock.Mock
|
|
kubeClient kubernetes.Interface
|
|
istioClient istioclient.Interface
|
|
cloudFoundryClient *cfclient.Client
|
|
dynamicKubernetesClient dynamic.Interface
|
|
openshiftClient openshift.Interface
|
|
}
|
|
|
|
func (m *MockClientGenerator) KubeClient() (kubernetes.Interface, error) {
|
|
args := m.Called()
|
|
if args.Error(1) == nil {
|
|
m.kubeClient = args.Get(0).(kubernetes.Interface)
|
|
return m.kubeClient, nil
|
|
}
|
|
return nil, args.Error(1)
|
|
}
|
|
|
|
func (m *MockClientGenerator) IstioClient() (istioclient.Interface, error) {
|
|
args := m.Called()
|
|
if args.Error(1) == nil {
|
|
m.istioClient = args.Get(0).(istioclient.Interface)
|
|
return m.istioClient, nil
|
|
}
|
|
return nil, args.Error(1)
|
|
}
|
|
|
|
func (m *MockClientGenerator) CloudFoundryClient(cfAPIEndpoint string, cfUsername string, cfPassword string) (*cfclient.Client, error) {
|
|
args := m.Called()
|
|
if args.Error(1) == nil {
|
|
m.cloudFoundryClient = args.Get(0).(*cfclient.Client)
|
|
return m.cloudFoundryClient, nil
|
|
}
|
|
return nil, args.Error(1)
|
|
}
|
|
|
|
func (m *MockClientGenerator) DynamicKubernetesClient() (dynamic.Interface, error) {
|
|
args := m.Called()
|
|
if args.Error(1) == nil {
|
|
m.dynamicKubernetesClient = args.Get(0).(dynamic.Interface)
|
|
return m.dynamicKubernetesClient, nil
|
|
}
|
|
return nil, args.Error(1)
|
|
}
|
|
|
|
func (m *MockClientGenerator) OpenShiftClient() (openshift.Interface, error) {
|
|
args := m.Called()
|
|
if args.Error(1) == nil {
|
|
m.openshiftClient = args.Get(0).(openshift.Interface)
|
|
return m.openshiftClient, nil
|
|
}
|
|
return nil, args.Error(1)
|
|
}
|
|
|
|
type ByNamesTestSuite struct {
|
|
suite.Suite
|
|
}
|
|
|
|
func (suite *ByNamesTestSuite) TestAllInitialized() {
|
|
fakeDynamic, _ := newDynamicKubernetesClient()
|
|
|
|
mockClientGenerator := new(MockClientGenerator)
|
|
mockClientGenerator.On("KubeClient").Return(fakeKube.NewSimpleClientset(), nil)
|
|
mockClientGenerator.On("IstioClient").Return(NewFakeConfigStore(), nil)
|
|
mockClientGenerator.On("DynamicKubernetesClient").Return(fakeDynamic, nil)
|
|
|
|
sources, err := ByNames(mockClientGenerator, []string{"service", "ingress", "istio-gateway", "contour-ingressroute", "contour-httpproxy", "fake"}, minimalConfig)
|
|
suite.NoError(err, "should not generate errors")
|
|
suite.Len(sources, 6, "should generate all six sources")
|
|
}
|
|
|
|
func (suite *ByNamesTestSuite) TestOnlyFake() {
|
|
mockClientGenerator := new(MockClientGenerator)
|
|
mockClientGenerator.On("KubeClient").Return(fakeKube.NewSimpleClientset(), nil)
|
|
|
|
sources, err := ByNames(mockClientGenerator, []string{"fake"}, minimalConfig)
|
|
suite.NoError(err, "should not generate errors")
|
|
suite.Len(sources, 1, "should generate fake source")
|
|
suite.Nil(mockClientGenerator.kubeClient, "client should not be created")
|
|
}
|
|
|
|
func (suite *ByNamesTestSuite) TestSourceNotFound() {
|
|
mockClientGenerator := new(MockClientGenerator)
|
|
mockClientGenerator.On("KubeClient").Return(fakeKube.NewSimpleClientset(), nil)
|
|
|
|
sources, err := ByNames(mockClientGenerator, []string{"foo"}, minimalConfig)
|
|
suite.Equal(err, ErrSourceNotFound, "should return source not found")
|
|
suite.Len(sources, 0, "should not returns any source")
|
|
}
|
|
|
|
func (suite *ByNamesTestSuite) TestKubeClientFails() {
|
|
mockClientGenerator := new(MockClientGenerator)
|
|
mockClientGenerator.On("KubeClient").Return(nil, errors.New("foo"))
|
|
|
|
_, err := ByNames(mockClientGenerator, []string{"service"}, minimalConfig)
|
|
suite.Error(err, "should return an error if kubernetes client cannot be created")
|
|
|
|
_, err = ByNames(mockClientGenerator, []string{"ingress"}, minimalConfig)
|
|
suite.Error(err, "should return an error if kubernetes client cannot be created")
|
|
|
|
_, err = ByNames(mockClientGenerator, []string{"istio-gateway"}, minimalConfig)
|
|
suite.Error(err, "should return an error if kubernetes client cannot be created")
|
|
|
|
_, err = ByNames(mockClientGenerator, []string{"contour-ingressroute"}, minimalConfig)
|
|
suite.Error(err, "should return an error if kubernetes client cannot be created")
|
|
}
|
|
|
|
func (suite *ByNamesTestSuite) TestIstioClientFails() {
|
|
mockClientGenerator := new(MockClientGenerator)
|
|
mockClientGenerator.On("KubeClient").Return(fakeKube.NewSimpleClientset(), nil)
|
|
mockClientGenerator.On("IstioClient").Return(nil, errors.New("foo"))
|
|
mockClientGenerator.On("DynamicKubernetesClient").Return(nil, errors.New("foo"))
|
|
|
|
_, err := ByNames(mockClientGenerator, []string{"istio-gateway"}, minimalConfig)
|
|
suite.Error(err, "should return an error if istio client cannot be created")
|
|
|
|
_, err = ByNames(mockClientGenerator, []string{"contour-ingressroute"}, minimalConfig)
|
|
suite.Error(err, "should return an error if contour client cannot be created")
|
|
_, err = ByNames(mockClientGenerator, []string{"contour-httpproxy"}, minimalConfig)
|
|
suite.Error(err, "should return an error if contour client cannot be created")
|
|
}
|
|
|
|
func TestByNames(t *testing.T) {
|
|
suite.Run(t, new(ByNamesTestSuite))
|
|
}
|
|
|
|
var minimalConfig = &Config{
|
|
ContourLoadBalancerService: "heptio-contour/contour",
|
|
}
|