| 
									
										
										
										
											2016-09-19 11:26:00 +01:00
										 |  |  | package dnsserver
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import "testing"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestNormalizeZone(t *testing.T) {
 | 
					
						
							|  |  |  | 	for i, test := range []struct {
 | 
					
						
							|  |  |  | 		input     string
 | 
					
						
							|  |  |  | 		expected  string
 | 
					
						
							|  |  |  | 		shouldErr bool
 | 
					
						
							|  |  |  | 	}{
 | 
					
						
							| 
									
										
										
										
											2017-03-13 20:24:37 +00:00
										 |  |  | 		{".", "dns://.:53", false},
 | 
					
						
							|  |  |  | 		{".:54", "dns://.:54", false},
 | 
					
						
							|  |  |  | 		{"..", "://:", true},
 | 
					
						
							| 
									
										
										
										
											2017-08-07 13:24:09 -07:00
										 |  |  | 		{".:", "://:", true},
 | 
					
						
							| 
									
										
										
										
											2018-07-21 19:06:13 +02:00
										 |  |  | 		{"dns://.", "dns://.:53", false},
 | 
					
						
							|  |  |  | 		{"dns://.:5353", "dns://.:5353", false},
 | 
					
						
							|  |  |  | 		{"dns://..", "://:", true},
 | 
					
						
							|  |  |  | 		{"dns://.:", "://:", true},
 | 
					
						
							|  |  |  | 		{"tls://.", "tls://.:853", false},
 | 
					
						
							|  |  |  | 		{"tls://.:8953", "tls://.:8953", false},
 | 
					
						
							|  |  |  | 		{"tls://..", "://:", true},
 | 
					
						
							|  |  |  | 		{"tls://.:", "://:", true},
 | 
					
						
							|  |  |  | 		{"grpc://.", "grpc://.:443", false},
 | 
					
						
							|  |  |  | 		{"grpc://.:8443", "grpc://.:8443", false},
 | 
					
						
							|  |  |  | 		{"grpc://..", "://:", true},
 | 
					
						
							|  |  |  | 		{"grpc://.:", "://:", true},
 | 
					
						
							|  |  |  | 		{"https://.", "https://.:443", false},
 | 
					
						
							|  |  |  | 		{"https://.:8443", "https://.:8443", false},
 | 
					
						
							|  |  |  | 		{"https://..", "://:", true},
 | 
					
						
							|  |  |  | 		{"https://.:", "://:", true},
 | 
					
						
							| 
									
										
										
										
											2017-08-07 13:24:09 -07:00
										 |  |  | 	} {
 | 
					
						
							|  |  |  | 		addr, err := normalizeZone(test.input)
 | 
					
						
							|  |  |  | 		actual := addr.String()
 | 
					
						
							|  |  |  | 		if test.shouldErr && err == nil {
 | 
					
						
							|  |  |  | 			t.Errorf("Test %d: Expected error, but there wasn't any", i)
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 		if !test.shouldErr && err != nil {
 | 
					
						
							|  |  |  | 			t.Errorf("Test %d: Expected no error, but there was one: %v", i, err)
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 		if actual != test.expected {
 | 
					
						
							|  |  |  | 			t.Errorf("Test %d: Expected %s but got %s", i, test.expected, actual)
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestNormalizeZoneReverse(t *testing.T) {
 | 
					
						
							|  |  |  | 	for i, test := range []struct {
 | 
					
						
							|  |  |  | 		input     string
 | 
					
						
							|  |  |  | 		expected  string
 | 
					
						
							|  |  |  | 		shouldErr bool
 | 
					
						
							|  |  |  | 	}{
 | 
					
						
							| 
									
										
										
										
											2018-01-23 10:58:36 -05:00
										 |  |  | 		{"2003::1/64", "dns://0.0.0.0.0.0.0.0.0.0.0.0.3.0.0.2.ip6.arpa.:53", false},
 | 
					
						
							| 
									
										
										
										
											2017-08-07 13:24:09 -07:00
										 |  |  | 		{"2003::1/64.", "dns://2003::1/64.:53", false}, // OK, with closing dot the parse will fail.
 | 
					
						
							| 
									
										
										
										
											2018-01-23 10:58:36 -05:00
										 |  |  | 		{"2003::1/64:53", "dns://0.0.0.0.0.0.0.0.0.0.0.0.3.0.0.2.ip6.arpa.:53", false},
 | 
					
						
							| 
									
										
										
										
											2017-08-07 13:24:09 -07:00
										 |  |  | 		{"2003::1/64.:53", "dns://2003::1/64.:53", false},
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		{"10.0.0.0/24", "dns://0.0.10.in-addr.arpa.:53", false},
 | 
					
						
							|  |  |  | 		{"10.0.0.0/24.", "dns://10.0.0.0/24.:53", false},
 | 
					
						
							|  |  |  | 		{"10.0.0.0/24:53", "dns://0.0.10.in-addr.arpa.:53", false},
 | 
					
						
							|  |  |  | 		{"10.0.0.0/24.:53", "dns://10.0.0.0/24.:53", false},
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// non %8==0 netmasks
 | 
					
						
							| 
									
										
										
										
											2018-01-23 10:58:36 -05:00
										 |  |  | 		{"2003::53/67", "dns://0.0.0.0.0.0.0.0.0.0.0.0.0.3.0.0.2.ip6.arpa.:53", false},
 | 
					
						
							| 
									
										
										
										
											2017-10-24 10:16:03 +01:00
										 |  |  | 		{"10.0.0.0/25.", "dns://10.0.0.0/25.:53", false}, // has dot
 | 
					
						
							|  |  |  | 		{"10.0.0.0/25", "dns://0.0.10.in-addr.arpa.:53", false},
 | 
					
						
							| 
									
										
										
										
											2018-01-23 10:58:36 -05:00
										 |  |  | 		{"fd00:77:30::0/110", "dns://0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.3.0.0.7.7.0.0.0.0.d.f.ip6.arpa.:53", false},
 | 
					
						
							| 
									
										
										
										
											2016-09-19 11:26:00 +01:00
										 |  |  | 	} {
 | 
					
						
							|  |  |  | 		addr, err := normalizeZone(test.input)
 | 
					
						
							|  |  |  | 		actual := addr.String()
 | 
					
						
							|  |  |  | 		if test.shouldErr && err == nil {
 | 
					
						
							|  |  |  | 			t.Errorf("Test %d: Expected error, but there wasn't any", i)
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 		if !test.shouldErr && err != nil {
 | 
					
						
							|  |  |  | 			t.Errorf("Test %d: Expected no error, but there was one: %v", i, err)
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 		if actual != test.expected {
 | 
					
						
							|  |  |  | 			t.Errorf("Test %d: Expected %s but got %s", i, test.expected, actual)
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | }
 | 
					
						
							| 
									
										
										
										
											2018-02-14 14:19:32 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 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)
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | }
 | 
					
						
							| 
									
										
										
										
											2018-02-23 11:54:42 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 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)
 | 
					
						
							|  |  |  | 					}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				}
 | 
					
						
							|  |  |  | 			}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							|  |  |  | }
 |