mirror of
https://github.com/kubernetes-sigs/external-dns.git
synced 2025-08-06 01:26:59 +02:00
* Add aws-zone-id flag * Add Zone ID filter * Update AWS provider and main * Make ZoneIDFilter generic * Implement ZoneIDFilter for all providers * Update CHANGELOG
243 lines
7.5 KiB
Go
243 lines
7.5 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 provider
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"testing"
|
|
|
|
"strconv"
|
|
|
|
"github.com/dnsimple/dnsimple-go/dnsimple"
|
|
"github.com/kubernetes-incubator/external-dns/endpoint"
|
|
"github.com/kubernetes-incubator/external-dns/plan"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/mock"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
var mockProvider dnsimpleProvider
|
|
var dnsimpleListRecordsResponse dnsimple.ZoneRecordsResponse
|
|
var dnsimpleListZonesResponse dnsimple.ZonesResponse
|
|
|
|
type mockDnsimpleZonesService struct{}
|
|
|
|
func TestDnsimpleServices(t *testing.T) {
|
|
// Setup example responses
|
|
firstZone := dnsimple.Zone{
|
|
ID: 1,
|
|
AccountID: 12345,
|
|
Name: "example.com",
|
|
}
|
|
secondZone := dnsimple.Zone{
|
|
ID: 2,
|
|
AccountID: 54321,
|
|
Name: "example-beta.com",
|
|
}
|
|
zones := []dnsimple.Zone{firstZone, secondZone}
|
|
dnsimpleListZonesResponse = dnsimple.ZonesResponse{
|
|
Response: dnsimple.Response{},
|
|
Data: zones,
|
|
}
|
|
firstRecord := dnsimple.ZoneRecord{
|
|
ID: 2,
|
|
ZoneID: "example.com",
|
|
ParentID: 0,
|
|
Name: "example",
|
|
Content: "target",
|
|
TTL: 3600,
|
|
Priority: 0,
|
|
Type: "CNAME",
|
|
}
|
|
secondRecord := dnsimple.ZoneRecord{
|
|
ID: 1,
|
|
ZoneID: "example.com",
|
|
ParentID: 0,
|
|
Name: "example-beta",
|
|
Content: "127.0.0.1",
|
|
TTL: 3600,
|
|
Priority: 0,
|
|
Type: "A",
|
|
}
|
|
records := []dnsimple.ZoneRecord{firstRecord, secondRecord}
|
|
dnsimpleListRecordsResponse = dnsimple.ZoneRecordsResponse{
|
|
Response: dnsimple.Response{},
|
|
Data: records,
|
|
}
|
|
|
|
// Setup mock services
|
|
mockDNS := &mockDnsimpleZoneServiceInterface{}
|
|
mockDNS.On("ListZones", "1", &dnsimple.ZoneListOptions{}).Return(&dnsimpleListZonesResponse, nil)
|
|
mockDNS.On("ListZones", "2", &dnsimple.ZoneListOptions{}).Return(nil, fmt.Errorf("Account ID not found"))
|
|
mockDNS.On("ListRecords", "1", "example.com", &dnsimple.ZoneRecordListOptions{}).Return(&dnsimpleListRecordsResponse, nil)
|
|
mockDNS.On("ListRecords", "1", "example-beta.com", &dnsimple.ZoneRecordListOptions{}).Return(&dnsimple.ZoneRecordsResponse{}, nil)
|
|
|
|
for _, record := range records {
|
|
simpleRecord := dnsimple.ZoneRecord{
|
|
Name: record.Name,
|
|
Type: record.Type,
|
|
Content: record.Content,
|
|
}
|
|
mockDNS.On("CreateRecord", "1", record.ZoneID, simpleRecord).Return(&dnsimple.ZoneRecordResponse{}, nil)
|
|
mockDNS.On("DeleteRecord", "1", record.ZoneID, record.ID).Return(&dnsimple.ZoneRecordResponse{}, nil)
|
|
mockDNS.On("UpdateRecord", "1", record.ZoneID, record.ID, simpleRecord).Return(&dnsimple.ZoneRecordResponse{}, nil)
|
|
}
|
|
|
|
mockProvider = dnsimpleProvider{client: mockDNS}
|
|
|
|
// Run tests on mock services
|
|
t.Run("Zones", testDnsimpleProviderZones)
|
|
t.Run("Records", testDnsimpleProviderRecords)
|
|
t.Run("ApplyChanges", testDnsimpleProviderApplyChanges)
|
|
t.Run("SuitableZone", testDnsimpleSuitableZone)
|
|
t.Run("GetRecordID", testDnsimpleGetRecordID)
|
|
}
|
|
|
|
func testDnsimpleProviderZones(t *testing.T) {
|
|
mockProvider.accountID = "1"
|
|
result, err := mockProvider.Zones()
|
|
assert.Nil(t, err)
|
|
validateDnsimpleZones(t, result, dnsimpleListZonesResponse.Data)
|
|
|
|
mockProvider.accountID = "2"
|
|
result, err = mockProvider.Zones()
|
|
assert.NotNil(t, err)
|
|
}
|
|
|
|
func testDnsimpleProviderRecords(t *testing.T) {
|
|
mockProvider.accountID = "1"
|
|
result, err := mockProvider.Records()
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, len(dnsimpleListRecordsResponse.Data), len(result))
|
|
|
|
mockProvider.accountID = "2"
|
|
result, err = mockProvider.Records()
|
|
assert.NotNil(t, err)
|
|
}
|
|
func testDnsimpleProviderApplyChanges(t *testing.T) {
|
|
changes := &plan.Changes{}
|
|
changes.Create = []*endpoint.Endpoint{{DNSName: "example.example.com", Target: "target", RecordType: endpoint.RecordTypeCNAME}}
|
|
changes.Delete = []*endpoint.Endpoint{{DNSName: "example-beta.example.com", Target: "127.0.0.1", RecordType: endpoint.RecordTypeA}}
|
|
changes.UpdateNew = []*endpoint.Endpoint{{DNSName: "example.example.com", Target: "target", RecordType: endpoint.RecordTypeCNAME}}
|
|
|
|
mockProvider.accountID = "1"
|
|
err := mockProvider.ApplyChanges(changes)
|
|
if err != nil {
|
|
t.Errorf("Failed to apply changes: %v", err)
|
|
}
|
|
}
|
|
|
|
func testDnsimpleSuitableZone(t *testing.T) {
|
|
mockProvider.accountID = "1"
|
|
zones, err := mockProvider.Zones()
|
|
assert.Nil(t, err)
|
|
|
|
zone := dnsimpleSuitableZone("example-beta.example.com", zones)
|
|
assert.Equal(t, zone.Name, "example.com")
|
|
}
|
|
|
|
func TestNewDnsimpleProvider(t *testing.T) {
|
|
os.Setenv("DNSIMPLE_OAUTH", "xxxxxxxxxxxxxxxxxxxxxxxxxx")
|
|
_, err := NewDnsimpleProvider(NewDomainFilter([]string{"example.com"}), NewZoneIDFilter([]string{""}), true)
|
|
if err == nil {
|
|
t.Errorf("Expected to fail new provider on bad token")
|
|
}
|
|
os.Unsetenv("DNSIMPLE_OAUTH")
|
|
if err == nil {
|
|
t.Errorf("Expected to fail new provider on empty token")
|
|
}
|
|
}
|
|
|
|
func testDnsimpleGetRecordID(t *testing.T) {
|
|
mockProvider.accountID = "1"
|
|
result, err := mockProvider.GetRecordID("example.com", "example")
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, 2, result)
|
|
|
|
result, err = mockProvider.GetRecordID("example.com", "example-beta")
|
|
assert.Nil(t, err)
|
|
assert.Equal(t, 1, result)
|
|
}
|
|
|
|
func validateDnsimpleZones(t *testing.T, zones map[string]dnsimple.Zone, expected []dnsimple.Zone) {
|
|
require.Len(t, zones, len(expected))
|
|
|
|
for _, e := range expected {
|
|
assert.Equal(t, zones[strconv.Itoa(e.ID)].Name, e.Name)
|
|
}
|
|
}
|
|
|
|
type mockDnsimpleZoneServiceInterface struct {
|
|
mock.Mock
|
|
}
|
|
|
|
func (_m *mockDnsimpleZoneServiceInterface) CreateRecord(accountID string, zoneID string, recordAttributes dnsimple.ZoneRecord) (*dnsimple.ZoneRecordResponse, error) {
|
|
args := _m.Called(accountID, zoneID, recordAttributes)
|
|
var r0 *dnsimple.ZoneRecordResponse
|
|
|
|
if args.Get(0) != nil {
|
|
r0 = args.Get(0).(*dnsimple.ZoneRecordResponse)
|
|
}
|
|
|
|
return r0, args.Error(1)
|
|
}
|
|
|
|
func (_m *mockDnsimpleZoneServiceInterface) DeleteRecord(accountID string, zoneID string, recordID int) (*dnsimple.ZoneRecordResponse, error) {
|
|
args := _m.Called(accountID, zoneID, recordID)
|
|
var r0 *dnsimple.ZoneRecordResponse
|
|
|
|
if args.Get(0) != nil {
|
|
r0 = args.Get(0).(*dnsimple.ZoneRecordResponse)
|
|
}
|
|
|
|
return r0, args.Error(1)
|
|
}
|
|
|
|
func (_m *mockDnsimpleZoneServiceInterface) ListRecords(accountID string, zoneID string, options *dnsimple.ZoneRecordListOptions) (*dnsimple.ZoneRecordsResponse, error) {
|
|
args := _m.Called(accountID, zoneID, options)
|
|
var r0 *dnsimple.ZoneRecordsResponse
|
|
|
|
if args.Get(0) != nil {
|
|
r0 = args.Get(0).(*dnsimple.ZoneRecordsResponse)
|
|
}
|
|
|
|
return r0, args.Error(1)
|
|
}
|
|
|
|
func (_m *mockDnsimpleZoneServiceInterface) ListZones(accountID string, options *dnsimple.ZoneListOptions) (*dnsimple.ZonesResponse, error) {
|
|
args := _m.Called(accountID, options)
|
|
var r0 *dnsimple.ZonesResponse
|
|
|
|
if args.Get(0) != nil {
|
|
r0 = args.Get(0).(*dnsimple.ZonesResponse)
|
|
}
|
|
|
|
return r0, args.Error(1)
|
|
}
|
|
|
|
func (_m *mockDnsimpleZoneServiceInterface) UpdateRecord(accountID string, zoneID string, recordID int, recordAttributes dnsimple.ZoneRecord) (*dnsimple.ZoneRecordResponse, error) {
|
|
args := _m.Called(accountID, zoneID, recordID, recordAttributes)
|
|
var r0 *dnsimple.ZoneRecordResponse
|
|
|
|
if args.Get(0) != nil {
|
|
r0 = args.Get(0).(*dnsimple.ZoneRecordResponse)
|
|
}
|
|
|
|
return r0, args.Error(1)
|
|
}
|