mirror of
				https://github.com/kubernetes-sigs/external-dns.git
				synced 2025-10-26 08:11:26 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			168 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			168 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
| Copyright 2018 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 registry
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"github.com/stretchr/testify/require"
 | |
| 
 | |
| 	"sigs.k8s.io/external-dns/endpoint"
 | |
| 	"sigs.k8s.io/external-dns/internal/testutils"
 | |
| 	"sigs.k8s.io/external-dns/plan"
 | |
| 	"sigs.k8s.io/external-dns/provider"
 | |
| )
 | |
| 
 | |
| type inMemoryProvider struct {
 | |
| 	provider.BaseProvider
 | |
| 	endpoints      []*endpoint.Endpoint
 | |
| 	onApplyChanges func(changes *plan.Changes)
 | |
| }
 | |
| 
 | |
| func (p *inMemoryProvider) Records(ctx context.Context) ([]*endpoint.Endpoint, error) {
 | |
| 	return p.endpoints, nil
 | |
| }
 | |
| 
 | |
| func (p *inMemoryProvider) ApplyChanges(ctx context.Context, changes *plan.Changes) error {
 | |
| 	p.onApplyChanges(changes)
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func newInMemoryProvider(endpoints []*endpoint.Endpoint, onApplyChanges func(changes *plan.Changes)) *inMemoryProvider {
 | |
| 	return &inMemoryProvider{
 | |
| 		endpoints:      endpoints,
 | |
| 		onApplyChanges: onApplyChanges,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestAWSSDRegistry_NewAWSSDRegistry(t *testing.T) {
 | |
| 	p := newInMemoryProvider(nil, nil)
 | |
| 	_, err := NewAWSSDRegistry(p, "")
 | |
| 	require.Error(t, err)
 | |
| 
 | |
| 	_, err = NewAWSSDRegistry(p, "owner")
 | |
| 	require.NoError(t, err)
 | |
| }
 | |
| 
 | |
| func TestAWSSDRegistryTest_Records(t *testing.T) {
 | |
| 	p := newInMemoryProvider([]*endpoint.Endpoint{
 | |
| 		newEndpointWithOwnerAndDescription("foo1.test-zone.example.org", "1.2.3.4", endpoint.RecordTypeA, "", ""),
 | |
| 		newEndpointWithOwnerAndDescription("foo2.test-zone.example.org", "1.2.3.4", endpoint.RecordTypeA, "owner", "\"heritage=external-dns,external-dns/owner=owner\""),
 | |
| 		newEndpointWithOwnerAndDescription("foo3.test-zone.example.org", "my-domain.com", endpoint.RecordTypeCNAME, "", ""),
 | |
| 		newEndpointWithOwnerAndDescription("foo4.test-zone.example.org", "my-domain.com", endpoint.RecordTypeCNAME, "owner", "\"heritage=external-dns,external-dns/owner=owner\""),
 | |
| 	}, nil)
 | |
| 	expectedRecords := []*endpoint.Endpoint{
 | |
| 		{
 | |
| 			DNSName:    "foo1.test-zone.example.org",
 | |
| 			Targets:    endpoint.Targets{"1.2.3.4"},
 | |
| 			RecordType: endpoint.RecordTypeA,
 | |
| 			Labels: map[string]string{
 | |
| 				endpoint.OwnerLabelKey: "",
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			DNSName:    "foo2.test-zone.example.org",
 | |
| 			Targets:    endpoint.Targets{"1.2.3.4"},
 | |
| 			RecordType: endpoint.RecordTypeA,
 | |
| 			Labels: map[string]string{
 | |
| 				endpoint.OwnerLabelKey: "owner",
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			DNSName:    "foo3.test-zone.example.org",
 | |
| 			Targets:    endpoint.Targets{"my-domain.com"},
 | |
| 			RecordType: endpoint.RecordTypeCNAME,
 | |
| 			Labels: map[string]string{
 | |
| 				endpoint.OwnerLabelKey: "",
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			DNSName:    "foo4.test-zone.example.org",
 | |
| 			Targets:    endpoint.Targets{"my-domain.com"},
 | |
| 			RecordType: endpoint.RecordTypeCNAME,
 | |
| 			Labels: map[string]string{
 | |
| 				endpoint.OwnerLabelKey: "owner",
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	r, _ := NewAWSSDRegistry(p, "owner")
 | |
| 	records, _ := r.Records(context.Background())
 | |
| 
 | |
| 	assert.True(t, testutils.SameEndpoints(records, expectedRecords))
 | |
| }
 | |
| 
 | |
| func TestAWSSDRegistry_Records_ApplyChanges(t *testing.T) {
 | |
| 	changes := &plan.Changes{
 | |
| 		Create: []*endpoint.Endpoint{
 | |
| 			newEndpointWithOwner("new-record-1.test-zone.example.org", "new-loadbalancer-1.lb.com", endpoint.RecordTypeCNAME, "owner"),
 | |
| 		},
 | |
| 		Delete: []*endpoint.Endpoint{
 | |
| 			newEndpointWithOwner("foobar.test-zone.example.org", "1.2.3.4", endpoint.RecordTypeA, "owner"),
 | |
| 		},
 | |
| 		UpdateNew: []*endpoint.Endpoint{
 | |
| 			newEndpointWithOwner("tar.test-zone.example.org", "new-tar.loadbalancer.com", endpoint.RecordTypeCNAME, "owner"),
 | |
| 		},
 | |
| 		UpdateOld: []*endpoint.Endpoint{
 | |
| 			newEndpointWithOwner("tar.test-zone.example.org", "tar.loadbalancer.com", endpoint.RecordTypeCNAME, "owner"),
 | |
| 		},
 | |
| 	}
 | |
| 	expected := &plan.Changes{
 | |
| 		Create: []*endpoint.Endpoint{
 | |
| 			newEndpointWithOwnerAndDescription("new-record-1.test-zone.example.org", "new-loadbalancer-1.lb.com", endpoint.RecordTypeCNAME, "owner", "\"heritage=external-dns,external-dns/owner=owner\""),
 | |
| 		},
 | |
| 		Delete: []*endpoint.Endpoint{
 | |
| 			newEndpointWithOwnerAndDescription("foobar.test-zone.example.org", "1.2.3.4", endpoint.RecordTypeA, "owner", "\"heritage=external-dns,external-dns/owner=owner\""),
 | |
| 		},
 | |
| 		UpdateNew: []*endpoint.Endpoint{
 | |
| 			newEndpointWithOwnerAndDescription("tar.test-zone.example.org", "new-tar.loadbalancer.com", endpoint.RecordTypeCNAME, "owner", "\"heritage=external-dns,external-dns/owner=owner\""),
 | |
| 		},
 | |
| 		UpdateOld: []*endpoint.Endpoint{
 | |
| 			newEndpointWithOwnerAndDescription("tar.test-zone.example.org", "tar.loadbalancer.com", endpoint.RecordTypeCNAME, "owner", "\"heritage=external-dns,external-dns/owner=owner\""),
 | |
| 		},
 | |
| 	}
 | |
| 	p := newInMemoryProvider(nil, func(got *plan.Changes) {
 | |
| 		mExpected := map[string][]*endpoint.Endpoint{
 | |
| 			"Create":    expected.Create,
 | |
| 			"UpdateNew": expected.UpdateNew,
 | |
| 			"UpdateOld": expected.UpdateOld,
 | |
| 			"Delete":    expected.Delete,
 | |
| 		}
 | |
| 		mGot := map[string][]*endpoint.Endpoint{
 | |
| 			"Create":    got.Create,
 | |
| 			"UpdateNew": got.UpdateNew,
 | |
| 			"UpdateOld": got.UpdateOld,
 | |
| 			"Delete":    got.Delete,
 | |
| 		}
 | |
| 		assert.True(t, testutils.SamePlanChanges(mGot, mExpected))
 | |
| 	})
 | |
| 	r, err := NewAWSSDRegistry(p, "owner")
 | |
| 	require.NoError(t, err)
 | |
| 
 | |
| 	err = r.ApplyChanges(context.Background(), changes)
 | |
| 	require.NoError(t, err)
 | |
| }
 | |
| 
 | |
| func newEndpointWithOwnerAndDescription(dnsName, target, recordType, ownerID string, description string) *endpoint.Endpoint {
 | |
| 	e := endpoint.NewEndpoint(dnsName, recordType, target)
 | |
| 	e.Labels[endpoint.OwnerLabelKey] = ownerID
 | |
| 	e.Labels[endpoint.AWSSDDescriptionLabel] = description
 | |
| 	return e
 | |
| }
 |