
Added support for AAAA record for coredns and included unit test. Fixed function names in comments for Google and AWS tests to match actual test name in this area.
195 lines
6.3 KiB
Go
195 lines
6.3 KiB
Go
/*
|
|
Copyright 2016 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 tests
|
|
|
|
import (
|
|
"reflect"
|
|
"testing"
|
|
|
|
"k8s.io/kubernetes/federation/pkg/dnsprovider"
|
|
"k8s.io/kubernetes/federation/pkg/dnsprovider/rrstype"
|
|
)
|
|
|
|
/* CommonTestResourceRecordSetsReplace verifies that replacing an RRS works */
|
|
func CommonTestResourceRecordSetsReplace(t *testing.T, zone dnsprovider.Zone) {
|
|
rrsets, _ := zone.ResourceRecordSets()
|
|
|
|
sets := rrs(t, zone)
|
|
rrset := rrsets.New("alpha.test.com", []string{"8.8.4.4"}, 40, rrstype.A)
|
|
addRrsetOrFail(t, sets, rrset)
|
|
defer sets.StartChangeset().Remove(rrset).Apply()
|
|
|
|
// Replace the record (change ttl and rrdatas)
|
|
newRrset := rrsets.New("alpha.test.com", []string{"8.8.8.8"}, 80, rrstype.A)
|
|
err := sets.StartChangeset().Add(newRrset).Remove(rrset).Apply()
|
|
if err != nil {
|
|
t.Errorf("Failed to replace resource record set %v -> %v: %v", rrset, newRrset, err)
|
|
} else {
|
|
defer sets.StartChangeset().Remove(newRrset).Apply()
|
|
t.Logf("Correctly replaced resource record %v -> %v", rrset, newRrset)
|
|
}
|
|
|
|
// Check that the record was updated
|
|
assertHasRecord(t, sets, newRrset)
|
|
}
|
|
|
|
/* CommonTestResourceRecordSetsReplaceAll verifies that we can remove an RRS and create one with a different name*/
|
|
func CommonTestResourceRecordSetsReplaceAll(t *testing.T, zone dnsprovider.Zone) {
|
|
rrsets, _ := zone.ResourceRecordSets()
|
|
|
|
sets := rrs(t, zone)
|
|
rrset := rrsets.New("alpha.test.com", []string{"8.8.4.4"}, 40, rrstype.A)
|
|
addRrsetOrFail(t, sets, rrset)
|
|
defer sets.StartChangeset().Remove(rrset).Apply()
|
|
|
|
newRrset := rrsets.New("beta.test.com", []string{"8.8.8.8"}, 80, rrstype.A)
|
|
|
|
// Try to add it again, and verify that the call fails.
|
|
err := sets.StartChangeset().Add(newRrset).Remove(rrset).Apply()
|
|
if err != nil {
|
|
t.Errorf("Failed to replace resource record set %v -> %v: %v", rrset, newRrset, err)
|
|
} else {
|
|
defer sets.StartChangeset().Remove(newRrset).Apply()
|
|
t.Logf("Correctly replaced resource record %v -> %v", rrset, newRrset)
|
|
}
|
|
|
|
// Check that it was updated
|
|
assertHasRecord(t, sets, newRrset)
|
|
assertNotHasRecord(t, sets, rrset.Name(), rrset.Type())
|
|
}
|
|
|
|
/* CommonTestResourceRecordSetsDifferentType verifies that we can add records of the same name but different types */
|
|
func CommonTestResourceRecordSetsDifferentTypes(t *testing.T, zone dnsprovider.Zone) {
|
|
rrsets, _ := zone.ResourceRecordSets()
|
|
|
|
sets := rrs(t, zone)
|
|
rrset := rrsets.New("alpha.test.com", []string{"8.8.4.4"}, 40, rrstype.A)
|
|
addRrsetOrFail(t, sets, rrset)
|
|
defer sets.StartChangeset().Remove(rrset).Apply()
|
|
|
|
aaaaRrset := rrsets.New("alpha.test.com", []string{"2001:4860:4860::8888"}, 80, rrstype.AAAA)
|
|
|
|
// Add the resource with the same name but different type
|
|
err := sets.StartChangeset().Add(aaaaRrset).Apply()
|
|
if err != nil {
|
|
t.Errorf("Failed to add resource record set %v: %v", aaaaRrset, err)
|
|
}
|
|
defer sets.StartChangeset().Remove(aaaaRrset).Apply()
|
|
|
|
// Check that both records exist
|
|
assertHasRecord(t, sets, aaaaRrset)
|
|
assertHasRecord(t, sets, rrset)
|
|
}
|
|
|
|
/* rrs returns the ResourceRecordSets interface for a given zone */
|
|
func rrs(t *testing.T, zone dnsprovider.Zone) (r dnsprovider.ResourceRecordSets) {
|
|
rrsets, supported := zone.ResourceRecordSets()
|
|
if !supported {
|
|
t.Fatalf("ResourceRecordSets interface not supported by zone %v", zone)
|
|
return r
|
|
}
|
|
return rrsets
|
|
}
|
|
|
|
func getRrOrFail(t *testing.T, rrsets dnsprovider.ResourceRecordSets, name string) []dnsprovider.ResourceRecordSet {
|
|
rrsetList, err := rrsets.Get(name)
|
|
if err != nil {
|
|
t.Fatalf("Failed to get recordset: %v", err)
|
|
} else if len(rrsetList) == 0 {
|
|
t.Logf("Did not Get recordset: %v", name)
|
|
} else {
|
|
t.Logf("Got recordset: %v", rrsetList[0].Name())
|
|
}
|
|
return rrsetList
|
|
}
|
|
|
|
// assertHasRecord tests that rrsets has a record equivalent to rrset
|
|
func assertHasRecord(t *testing.T, rrsets dnsprovider.ResourceRecordSets, rrset dnsprovider.ResourceRecordSet) {
|
|
var found dnsprovider.ResourceRecordSet
|
|
|
|
rrs, err := rrsets.List()
|
|
if err != nil {
|
|
if err.Error() == "OperationNotSupported" {
|
|
foundList := getRrOrFail(t, rrsets, rrset.Name())
|
|
for i, elem := range foundList {
|
|
if elem.Name() == rrset.Name() && elem.Type() == rrset.Type() {
|
|
found = foundList[i]
|
|
break
|
|
}
|
|
}
|
|
} else {
|
|
t.Fatalf("Failed to list recordsets: %v", err)
|
|
}
|
|
} else {
|
|
if len(rrs) < 0 {
|
|
t.Fatalf("Record set length=%d, expected >=0", len(rrs))
|
|
} else {
|
|
t.Logf("Got %d recordsets: %v", len(rrs), rrs)
|
|
}
|
|
|
|
for _, r := range rrs {
|
|
if r.Name() != rrset.Name() || r.Type() != rrset.Type() {
|
|
continue
|
|
}
|
|
|
|
if found != nil {
|
|
t.Errorf("found duplicate resource record set: %q and %q", r, found)
|
|
}
|
|
found = r
|
|
}
|
|
}
|
|
|
|
if found == nil {
|
|
t.Errorf("resource record set %v not found", rrset)
|
|
} else {
|
|
assertEquivalent(t, found, rrset)
|
|
}
|
|
}
|
|
|
|
// assertNotHasRecord tests that rrsets does not have a record matching name and type
|
|
func assertNotHasRecord(t *testing.T, rrsets dnsprovider.ResourceRecordSets, name string, rrstype rrstype.RrsType) {
|
|
found := getRrOrFail(t, rrsets, name)
|
|
if found != nil {
|
|
t.Errorf("resource record set found unexpectedly: %v", found)
|
|
}
|
|
}
|
|
|
|
// assertEquivalent tests that l is equal to r, for the methods in ResourceRecordSet
|
|
func assertEquivalent(t *testing.T, l, r dnsprovider.ResourceRecordSet) {
|
|
if l.Name() != r.Name() {
|
|
t.Errorf("resource record sets not equal %v vs %v", l, r)
|
|
}
|
|
if l.Type() != r.Type() {
|
|
t.Errorf("resource record sets not equal %v vs %v", l, r)
|
|
}
|
|
if l.Ttl() != r.Ttl() {
|
|
t.Errorf("resource record sets not equal %v vs %v", l, r)
|
|
}
|
|
if !reflect.DeepEqual(l.Rrdatas(), r.Rrdatas()) {
|
|
t.Errorf("resource record sets not equal %v vs %v", l, r)
|
|
}
|
|
}
|
|
|
|
func addRrsetOrFail(t *testing.T, rrsets dnsprovider.ResourceRecordSets, rrset dnsprovider.ResourceRecordSet) {
|
|
err := rrsets.StartChangeset().Add(rrset).Apply()
|
|
if err != nil {
|
|
t.Fatalf("Failed to add recordset %v: %v", rrset, err)
|
|
} else {
|
|
t.Logf("Successfully added resource record set: %v", rrset)
|
|
}
|
|
}
|