Add a test for this as well as it's annoying to point out in every code review. Fix all the import paths that are flagged by this new test. Fixes: #3634 Signed-off-by: Miek Gieben <miek@miek.nl>
149 lines
3.8 KiB
Go
149 lines
3.8 KiB
Go
package kubernetes
|
|
|
|
import (
|
|
"net"
|
|
"testing"
|
|
|
|
"github.com/coredns/coredns/plugin/kubernetes/object"
|
|
|
|
"github.com/miekg/dns"
|
|
api "k8s.io/api/core/v1"
|
|
)
|
|
|
|
type APIConnTest struct{}
|
|
|
|
func (APIConnTest) HasSynced() bool { return true }
|
|
func (APIConnTest) Run() {}
|
|
func (APIConnTest) Stop() error { return nil }
|
|
func (APIConnTest) PodIndex(string) []*object.Pod { return nil }
|
|
func (APIConnTest) SvcIndexReverse(string) []*object.Service { return nil }
|
|
func (APIConnTest) EpIndex(string) []*object.Endpoints { return nil }
|
|
func (APIConnTest) EndpointsList() []*object.Endpoints { return nil }
|
|
func (APIConnTest) Modified() int64 { return 0 }
|
|
|
|
func (a APIConnTest) SvcIndex(s string) []*object.Service {
|
|
switch s {
|
|
case "dns-service.kube-system":
|
|
return []*object.Service{a.ServiceList()[0]}
|
|
case "hdls-dns-service.kube-system":
|
|
return []*object.Service{a.ServiceList()[1]}
|
|
case "dns6-service.kube-system":
|
|
return []*object.Service{a.ServiceList()[2]}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (APIConnTest) ServiceList() []*object.Service {
|
|
svcs := []*object.Service{
|
|
{
|
|
Name: "dns-service",
|
|
Namespace: "kube-system",
|
|
ClusterIP: "10.0.0.111",
|
|
},
|
|
{
|
|
Name: "hdls-dns-service",
|
|
Namespace: "kube-system",
|
|
ClusterIP: api.ClusterIPNone,
|
|
},
|
|
{
|
|
Name: "dns6-service",
|
|
Namespace: "kube-system",
|
|
ClusterIP: "10::111",
|
|
},
|
|
}
|
|
return svcs
|
|
}
|
|
|
|
func (APIConnTest) EpIndexReverse(ip string) []*object.Endpoints {
|
|
if ip != "10.244.0.20" {
|
|
return nil
|
|
}
|
|
eps := []*object.Endpoints{
|
|
{
|
|
Subsets: []object.EndpointSubset{
|
|
{
|
|
Addresses: []object.EndpointAddress{
|
|
{
|
|
IP: "10.244.0.20",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
Name: "dns-service",
|
|
Namespace: "kube-system",
|
|
},
|
|
{
|
|
Subsets: []object.EndpointSubset{
|
|
{
|
|
Addresses: []object.EndpointAddress{
|
|
{
|
|
IP: "10.244.0.20",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
Name: "hdls-dns-service",
|
|
Namespace: "kube-system",
|
|
},
|
|
{
|
|
Subsets: []object.EndpointSubset{
|
|
{
|
|
Addresses: []object.EndpointAddress{
|
|
{
|
|
IP: "10.244.0.20",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
Name: "dns6-service",
|
|
Namespace: "kube-system",
|
|
},
|
|
}
|
|
return eps
|
|
}
|
|
|
|
func (APIConnTest) GetNodeByName(name string) (*api.Node, error) { return &api.Node{}, nil }
|
|
func (APIConnTest) GetNamespaceByName(name string) (*api.Namespace, error) {
|
|
return &api.Namespace{}, nil
|
|
}
|
|
|
|
func TestNsAddrs(t *testing.T) {
|
|
|
|
k := New([]string{"inter.webs.test."})
|
|
k.APIConn = &APIConnTest{}
|
|
k.localIPs = []net.IP{net.ParseIP("10.244.0.20")}
|
|
|
|
cdrs := k.nsAddrs(false, k.Zones[0])
|
|
|
|
if len(cdrs) != 3 {
|
|
t.Fatalf("Expected 3 results, got %v", len(cdrs))
|
|
|
|
}
|
|
cdr := cdrs[0]
|
|
expected := "10.0.0.111"
|
|
if cdr.(*dns.A).A.String() != expected {
|
|
t.Errorf("Expected 1st A to be %q, got %q", expected, cdr.(*dns.A).A.String())
|
|
}
|
|
expected = "dns-service.kube-system.svc.inter.webs.test."
|
|
if cdr.Header().Name != expected {
|
|
t.Errorf("Expected 1st Header Name to be %q, got %q", expected, cdr.Header().Name)
|
|
}
|
|
cdr = cdrs[1]
|
|
expected = "10.244.0.20"
|
|
if cdr.(*dns.A).A.String() != expected {
|
|
t.Errorf("Expected 2nd A to be %q, got %q", expected, cdr.(*dns.A).A.String())
|
|
}
|
|
expected = "10-244-0-20.hdls-dns-service.kube-system.svc.inter.webs.test."
|
|
if cdr.Header().Name != expected {
|
|
t.Errorf("Expected 2nd Header Name to be %q, got %q", expected, cdr.Header().Name)
|
|
}
|
|
cdr = cdrs[2]
|
|
expected = "10::111"
|
|
if cdr.(*dns.AAAA).AAAA.String() != expected {
|
|
t.Errorf("Expected AAAA to be %q, got %q", expected, cdr.(*dns.A).A.String())
|
|
}
|
|
expected = "dns6-service.kube-system.svc.inter.webs.test."
|
|
if cdr.Header().Name != expected {
|
|
t.Errorf("Expected AAAA Header Name to be %q, got %q", expected, cdr.Header().Name)
|
|
}
|
|
}
|