mirror of
				https://github.com/kubernetes-sigs/external-dns.git
				synced 2025-10-26 01:00: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",
 | |
| }
 |