mirror of
				https://github.com/coredns/coredns.git
				synced 2025-11-04 03:03:14 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			84 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package proxy
 | 
						|
 | 
						|
import (
 | 
						|
	"testing"
 | 
						|
	"time"
 | 
						|
)
 | 
						|
 | 
						|
func TestHealthCheck(t *testing.T) {
 | 
						|
	upstream := &staticUpstream{
 | 
						|
		from:        "",
 | 
						|
		Hosts:       testPool(),
 | 
						|
		Policy:      &Random{},
 | 
						|
		FailTimeout: 10 * time.Second,
 | 
						|
		MaxFails:    1,
 | 
						|
	}
 | 
						|
	upstream.healthCheck()
 | 
						|
	if upstream.Hosts[0].Down() {
 | 
						|
		t.Error("Expected first host in testpool to not fail healthcheck.")
 | 
						|
	}
 | 
						|
	if !upstream.Hosts[1].Down() {
 | 
						|
		t.Error("Expected second host in testpool to fail healthcheck.")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestSelect(t *testing.T) {
 | 
						|
	upstream := &staticUpstream{
 | 
						|
		from:        "",
 | 
						|
		Hosts:       testPool()[:3],
 | 
						|
		Policy:      &Random{},
 | 
						|
		FailTimeout: 10 * time.Second,
 | 
						|
		MaxFails:    1,
 | 
						|
	}
 | 
						|
	upstream.Hosts[0].Unhealthy = true
 | 
						|
	upstream.Hosts[1].Unhealthy = true
 | 
						|
	upstream.Hosts[2].Unhealthy = true
 | 
						|
	if h := upstream.Select(); h != nil {
 | 
						|
		t.Error("Expected select to return nil as all host are down")
 | 
						|
	}
 | 
						|
	upstream.Hosts[2].Unhealthy = false
 | 
						|
	if h := upstream.Select(); h == nil {
 | 
						|
		t.Error("Expected select to not return nil")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestRegisterPolicy(t *testing.T) {
 | 
						|
	name := "custom"
 | 
						|
	customPolicy := &customPolicy{}
 | 
						|
	RegisterPolicy(name, func() Policy { return customPolicy })
 | 
						|
	if _, ok := supportedPolicies[name]; !ok {
 | 
						|
		t.Error("Expected supportedPolicies to have a custom policy.")
 | 
						|
	}
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
func TestAllowedPaths(t *testing.T) {
 | 
						|
	upstream := &staticUpstream{
 | 
						|
		from:            "/proxy",
 | 
						|
		IgnoredSubPaths: []string{"/download", "/static"},
 | 
						|
	}
 | 
						|
	tests := []struct {
 | 
						|
		url      string
 | 
						|
		expected bool
 | 
						|
	}{
 | 
						|
		{"/proxy", true},
 | 
						|
		{"/proxy/dl", true},
 | 
						|
		{"/proxy/download", false},
 | 
						|
		{"/proxy/download/static", false},
 | 
						|
		{"/proxy/static", false},
 | 
						|
		{"/proxy/static/download", false},
 | 
						|
		{"/proxy/something/download", true},
 | 
						|
		{"/proxy/something/static", true},
 | 
						|
		{"/proxy//static", false},
 | 
						|
		{"/proxy//static//download", false},
 | 
						|
		{"/proxy//download", false},
 | 
						|
	}
 | 
						|
 | 
						|
	for i, test := range tests {
 | 
						|
		isAllowed := upstream.IsAllowedPath(test.url)
 | 
						|
		if test.expected != isAllowed {
 | 
						|
			t.Errorf("Test %d: expected %v found %v", i+1, test.expected, isAllowed)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |