mirror of
				https://github.com/coredns/coredns.git
				synced 2025-11-03 18:53:13 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			328 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			328 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package proxy
 | 
						|
 | 
						|
import (
 | 
						|
	"path/filepath"
 | 
						|
	"strings"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/coredns/coredns/plugin/test"
 | 
						|
 | 
						|
	"github.com/mholt/caddy"
 | 
						|
)
 | 
						|
 | 
						|
func TestAllowedDomain(t *testing.T) {
 | 
						|
	upstream := &staticUpstream{
 | 
						|
		from:              "miek.nl.",
 | 
						|
		IgnoredSubDomains: []string{"download.miek.nl.", "static.miek.nl."}, // closing dot mandatory
 | 
						|
	}
 | 
						|
	tests := []struct {
 | 
						|
		name     string
 | 
						|
		expected bool
 | 
						|
	}{
 | 
						|
		{"miek.nl.", true},
 | 
						|
		{"download.miek.nl.", false},
 | 
						|
		{"static.miek.nl.", false},
 | 
						|
		{"blaat.miek.nl.", true},
 | 
						|
	}
 | 
						|
 | 
						|
	for i, test := range tests {
 | 
						|
		isAllowed := upstream.IsAllowedDomain(test.name)
 | 
						|
		if test.expected != isAllowed {
 | 
						|
			t.Errorf("Test %d: expected %v found %v for %s", i+1, test.expected, isAllowed, test.name)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestProxyParse(t *testing.T) {
 | 
						|
	rmFunc, cert, key, ca := getPEMFiles(t)
 | 
						|
	defer rmFunc()
 | 
						|
 | 
						|
	grpc1 := "proxy . 8.8.8.8:53 {\n protocol grpc " + ca + "\n}"
 | 
						|
	grpc2 := "proxy . 8.8.8.8:53 {\n protocol grpc " + cert + " " + key + "\n}"
 | 
						|
	grpc3 := "proxy . 8.8.8.8:53 {\n protocol grpc " + cert + " " + key + " " + ca + "\n}"
 | 
						|
	grpc4 := "proxy . 8.8.8.8:53 {\n protocol grpc " + key + "\n}"
 | 
						|
 | 
						|
	tests := []struct {
 | 
						|
		inputUpstreams string
 | 
						|
		shouldErr      bool
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			`proxy . 8.8.8.8:53`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`proxy 10.0.0.0/24 8.8.8.8:53`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
    policy round_robin
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
    fail_timeout 5s
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
    max_fails 10
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
    health_check /health:8080
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
    except miek.nl example.org 10.0.0.0/24
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
    spray
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
    error_option
 | 
						|
}`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . some_bogus_filename`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	protocol dns
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	protocol grpc
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	protocol grpc insecure
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	protocol dns force_tcp
 | 
						|
}`,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	protocol grpc a b c d
 | 
						|
}`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			grpc1,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			grpc2,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			grpc3,
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			grpc4,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	protocol foobar
 | 
						|
}`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`proxy`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	protocol foobar
 | 
						|
}`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	policy
 | 
						|
}`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	fail_timeout
 | 
						|
}`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	fail_timeout junky
 | 
						|
}`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	health_check
 | 
						|
}`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . 8.8.8.8:53 {
 | 
						|
	protocol dns force
 | 
						|
}`,
 | 
						|
			true,
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for i, test := range tests {
 | 
						|
		c := caddy.NewTestController("dns", test.inputUpstreams)
 | 
						|
		_, err := NewStaticUpstreams(&c.Dispenser)
 | 
						|
		if (err != nil) != test.shouldErr {
 | 
						|
			t.Errorf("Test %d expected no error, got %v for %s", i+1, err, test.inputUpstreams)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestResolvParse(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		inputUpstreams string
 | 
						|
		filedata       string
 | 
						|
		shouldErr      bool
 | 
						|
		expected       []string
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy . FILE
 | 
						|
`,
 | 
						|
			`
 | 
						|
nameserver 1.2.3.4
 | 
						|
nameserver 4.3.2.1
 | 
						|
`,
 | 
						|
			false,
 | 
						|
			[]string{"1.2.3.4:53", "4.3.2.1:53"},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy example.com 1.1.1.1:5000
 | 
						|
proxy . FILE
 | 
						|
proxy example.org 2.2.2.2:1234
 | 
						|
`,
 | 
						|
			`
 | 
						|
nameserver 1.2.3.4
 | 
						|
`,
 | 
						|
			false,
 | 
						|
			[]string{"1.1.1.1:5000", "1.2.3.4:53", "2.2.2.2:1234"},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			`
 | 
						|
proxy example.com 1.1.1.1:5000
 | 
						|
proxy . FILE
 | 
						|
proxy example.org 2.2.2.2:1234
 | 
						|
`,
 | 
						|
			`
 | 
						|
junky resolv.conf
 | 
						|
`,
 | 
						|
			false,
 | 
						|
			[]string{"1.1.1.1:5000", "2.2.2.2:1234"},
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for i, tc := range tests {
 | 
						|
 | 
						|
		path, rm, err := test.TempFile(".", tc.filedata)
 | 
						|
		if err != nil {
 | 
						|
			t.Fatalf("Test %d could not creat temp file %v", i, err)
 | 
						|
		}
 | 
						|
		defer rm()
 | 
						|
 | 
						|
		config := strings.Replace(tc.inputUpstreams, "FILE", path, -1)
 | 
						|
		c := caddy.NewTestController("dns", config)
 | 
						|
		upstreams, err := NewStaticUpstreams(&c.Dispenser)
 | 
						|
		if (err != nil) != tc.shouldErr {
 | 
						|
			t.Errorf("Test %d expected no error, got %v", i+1, err)
 | 
						|
		}
 | 
						|
		var hosts []string
 | 
						|
		for _, u := range upstreams {
 | 
						|
			for _, h := range u.(*staticUpstream).Hosts {
 | 
						|
				hosts = append(hosts, h.Name)
 | 
						|
			}
 | 
						|
		}
 | 
						|
		if !tc.shouldErr {
 | 
						|
			if len(hosts) != len(tc.expected) {
 | 
						|
				t.Errorf("Test %d expected %d hosts got %d", i+1, len(tc.expected), len(upstreams))
 | 
						|
			} else {
 | 
						|
				ok := true
 | 
						|
				for i, v := range tc.expected {
 | 
						|
					if v != hosts[i] {
 | 
						|
						ok = false
 | 
						|
					}
 | 
						|
				}
 | 
						|
				if !ok {
 | 
						|
					t.Errorf("Test %d expected %v got %v", i+1, tc.expected, upstreams)
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestMaxTo(t *testing.T) {
 | 
						|
	// Has 16 IP addresses.
 | 
						|
	config := `proxy . 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1 1.1.1.1`
 | 
						|
	c := caddy.NewTestController("dns", config)
 | 
						|
	_, err := NewStaticUpstreams(&c.Dispenser)
 | 
						|
	if err == nil {
 | 
						|
		t.Error("Expected to many TOs configured, but nil")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func getPEMFiles(t *testing.T) (rmFunc func(), cert, key, ca string) {
 | 
						|
	tempDir, rmFunc, err := test.WritePEMFiles("")
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("Could not write PEM files: %s", err)
 | 
						|
	}
 | 
						|
 | 
						|
	cert = filepath.Join(tempDir, "cert.pem")
 | 
						|
	key = filepath.Join(tempDir, "key.pem")
 | 
						|
	ca = filepath.Join(tempDir, "ca.pem")
 | 
						|
 | 
						|
	return
 | 
						|
}
 |