mirror of
				https://github.com/coredns/coredns.git
				synced 2025-11-03 18:53:13 -05:00 
			
		
		
		
	* parse.HostPortorFile: return error when 0 found Return an error when we haven't found any nameservers. This is the alternative considered in #3735. It's also slighly less code to be changing. Replaces: #3741 Closes: #3741 #3735 Signed-off-by: Miek Gieben <miek@miek.nl> * Add extra test case here as well Signed-off-by: Miek Gieben <miek@miek.nl>
		
			
				
	
	
		
			113 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			113 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package parse
 | 
						|
 | 
						|
import (
 | 
						|
	"io/ioutil"
 | 
						|
	"os"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/coredns/coredns/plugin/pkg/transport"
 | 
						|
)
 | 
						|
 | 
						|
func TestHostPortOrFile(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		in        string
 | 
						|
		expected  string
 | 
						|
		shouldErr bool
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			"8.8.8.8",
 | 
						|
			"8.8.8.8:53",
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			"8.8.8.8:153",
 | 
						|
			"8.8.8.8:153",
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			"/etc/resolv.conf:53",
 | 
						|
			"",
 | 
						|
			true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			"resolv.conf",
 | 
						|
			"127.0.0.1:53",
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			"fe80::1",
 | 
						|
			"[fe80::1]:53",
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			"fe80::1%ens3",
 | 
						|
			"[fe80::1%ens3]:53",
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			"[fd01::1]:153",
 | 
						|
			"[fd01::1]:153",
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			"[fd01::1%ens3]:153",
 | 
						|
			"[fd01::1%ens3]:153",
 | 
						|
			false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			"8.9.1043",
 | 
						|
			"",
 | 
						|
			true,
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	err := ioutil.WriteFile("resolv.conf", []byte("nameserver 127.0.0.1\n"), 0600)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("Failed to write test resolv.conf")
 | 
						|
	}
 | 
						|
	defer os.Remove("resolv.conf")
 | 
						|
 | 
						|
	for i, tc := range tests {
 | 
						|
		got, err := HostPortOrFile(tc.in)
 | 
						|
		if err == nil && tc.shouldErr {
 | 
						|
			t.Errorf("Test %d, expected error, got nil", i)
 | 
						|
			continue
 | 
						|
		}
 | 
						|
		if err != nil && tc.shouldErr {
 | 
						|
			continue
 | 
						|
		}
 | 
						|
		if got[0] != tc.expected {
 | 
						|
			t.Errorf("Test %d, expected %q, got %q", i, tc.expected, got[0])
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestParseHostPort(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		in        string
 | 
						|
		expected  string
 | 
						|
		shouldErr bool
 | 
						|
	}{
 | 
						|
		{"8.8.8.8:53", "8.8.8.8:53", false},
 | 
						|
		{"a.a.a.a:153", "", true},
 | 
						|
		{"8.8.8.8", "8.8.8.8:53", false},
 | 
						|
		{"8.8.8.8:", "8.8.8.8:53", false},
 | 
						|
		{"8.8.8.8::53", "", true},
 | 
						|
		{"resolv.conf", "", true},
 | 
						|
	}
 | 
						|
 | 
						|
	for i, tc := range tests {
 | 
						|
		got, err := HostPort(tc.in, transport.Port)
 | 
						|
		if err == nil && tc.shouldErr {
 | 
						|
			t.Errorf("Test %d, expected error, got nil", i)
 | 
						|
			continue
 | 
						|
		}
 | 
						|
		if err != nil && !tc.shouldErr {
 | 
						|
			t.Errorf("Test %d, expected no error, got %q", i, err)
 | 
						|
		}
 | 
						|
		if got != tc.expected {
 | 
						|
			t.Errorf("Test %d, expected %q, got %q", i, tc.expected, got)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |