mirror of
				https://github.com/coredns/coredns.git
				synced 2025-11-03 02:33:21 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			114 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package dnsserver
 | 
						|
 | 
						|
import "testing"
 | 
						|
 | 
						|
func TestSplitProtocolHostPort(t *testing.T) {
 | 
						|
	for i, test := range []struct {
 | 
						|
		input     string
 | 
						|
		proto     string
 | 
						|
		ip        string
 | 
						|
		port      string
 | 
						|
		shouldErr bool
 | 
						|
	}{
 | 
						|
		{"dns://:53", "dns", "", "53", false},
 | 
						|
		{"dns://127.0.0.1:4005", "dns", "127.0.0.1", "4005", false},
 | 
						|
		{"[ffe0:34ab:1]:4005", "", "ffe0:34ab:1", "4005", false},
 | 
						|
 | 
						|
		// port part is mandatory
 | 
						|
		{"dns://", "dns", "", "", true},
 | 
						|
		{"dns://127.0.0.1", "dns", "127.0.0.1", "", true},
 | 
						|
		// cannot be empty
 | 
						|
		{"", "", "", "", true},
 | 
						|
		// invalid format with twice ://
 | 
						|
		{"dns://127.0.0.1://53", "", "", "", true},
 | 
						|
	} {
 | 
						|
		proto, ip, port, err := SplitProtocolHostPort(test.input)
 | 
						|
		if test.shouldErr && err == nil {
 | 
						|
			t.Errorf("Test %d: (address = %s) expected error, but there wasn't any", i, test.input)
 | 
						|
			continue
 | 
						|
		}
 | 
						|
		if !test.shouldErr && err != nil {
 | 
						|
			t.Errorf("Test %d: (address = %s) expected no error, but there was one: %v", i, test.input, err)
 | 
						|
			continue
 | 
						|
		}
 | 
						|
		if err == nil || test.shouldErr {
 | 
						|
			continue
 | 
						|
		}
 | 
						|
		if proto != test.proto {
 | 
						|
			t.Errorf("Test %d: (address = %s) expected protocol with value %s but got %s", i, test.input, test.proto, proto)
 | 
						|
		}
 | 
						|
		if ip != test.ip {
 | 
						|
			t.Errorf("Test %d: (address = %s) expected ip with value %s but got %s", i, test.input, test.ip, ip)
 | 
						|
		}
 | 
						|
		if port != test.port {
 | 
						|
			t.Errorf("Test %d: (address = %s) expected port with value %s but got %s", i, test.input, test.port, port)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
type checkCall struct {
 | 
						|
	zone       zoneAddr
 | 
						|
	same       bool
 | 
						|
	overlap    bool
 | 
						|
	overlapKey string
 | 
						|
}
 | 
						|
 | 
						|
type checkTest struct {
 | 
						|
	sequence []checkCall
 | 
						|
}
 | 
						|
 | 
						|
func TestOverlapAddressChecker(t *testing.T) {
 | 
						|
	for i, test := range []checkTest{
 | 
						|
		{sequence: []checkCall{
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "", Port: "53"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "", Port: "53"}, true, false, ""},
 | 
						|
		},
 | 
						|
		},
 | 
						|
		{sequence: []checkCall{
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "", Port: "53"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "", Port: "54"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "127.0.0.1", Port: "53"}, false, true, "dns://.:53"},
 | 
						|
		},
 | 
						|
		},
 | 
						|
		{sequence: []checkCall{
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "127.0.0.1", Port: "53"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "", Port: "54"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "127.0.0.1", Port: "53"}, true, false, ""},
 | 
						|
		},
 | 
						|
		},
 | 
						|
		{sequence: []checkCall{
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "127.0.0.1", Port: "53"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "", Port: "54"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "128.0.0.1", Port: "53"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "129.0.0.1", Port: "53"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "", Port: "53"}, false, true, "dns://.:53 on 129.0.0.1"},
 | 
						|
		},
 | 
						|
		},
 | 
						|
		{sequence: []checkCall{
 | 
						|
			{zoneAddr{Transport: "dns", Zone: ".", Address: "127.0.0.1", Port: "53"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: "com.", Address: "127.0.0.1", Port: "53"}, false, false, ""},
 | 
						|
			{zoneAddr{Transport: "dns", Zone: "com.", Address: "", Port: "53"}, false, true, "dns://com.:53 on 127.0.0.1"},
 | 
						|
		},
 | 
						|
		},
 | 
						|
	} {
 | 
						|
		checker := newOverlapZone()
 | 
						|
		for _, call := range test.sequence {
 | 
						|
			same, overlap := checker.registerAndCheck(call.zone)
 | 
						|
			sZone := call.zone.String()
 | 
						|
			if (same != nil) != call.same {
 | 
						|
				t.Errorf("Test %d: error, for zone %s, 'same' (%v) has not the expected value (%v)", i, sZone, same != nil, call.same)
 | 
						|
			}
 | 
						|
			if same == nil {
 | 
						|
				if (overlap != nil) != call.overlap {
 | 
						|
					t.Errorf("Test %d: error, for zone %s, 'overlap' (%v) has not the expected value (%v)", i, sZone, overlap != nil, call.overlap)
 | 
						|
				}
 | 
						|
				if overlap != nil {
 | 
						|
					if overlap.String() != call.overlapKey {
 | 
						|
						t.Errorf("Test %d: error, for zone %s, 'overlap Key' (%v) has not the expected value (%v)", i, sZone, overlap.String(), call.overlapKey)
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |