mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-26 00:02:45 -04:00 
			
		
		
		
	Merge pull request #94 from acmacalister/feature/custom-policies
added custom policy support
This commit is contained in:
		
						commit
						9bdd9bdecc
					
				| @ -13,6 +13,12 @@ type Policy interface { | |||||||
| 	Select(pool HostPool) *UpstreamHost | 	Select(pool HostPool) *UpstreamHost | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func init() { | ||||||
|  | 	RegisterPolicy("random", func() Policy { return &Random{} }) | ||||||
|  | 	RegisterPolicy("least_conn", func() Policy { return &LeastConn{} }) | ||||||
|  | 	RegisterPolicy("round_robin", func() Policy { return &RoundRobin{} }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // Random is a policy that selects up hosts from a pool at random. | // Random is a policy that selects up hosts from a pool at random. | ||||||
| type Random struct{} | type Random struct{} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -4,6 +4,12 @@ import ( | |||||||
| 	"testing" | 	"testing" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | type customPolicy struct{} | ||||||
|  | 
 | ||||||
|  | func (r *customPolicy) Select(pool HostPool) *UpstreamHost { | ||||||
|  | 	return pool[0] | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func testPool() HostPool { | func testPool() HostPool { | ||||||
| 	pool := []*UpstreamHost{ | 	pool := []*UpstreamHost{ | ||||||
| 		&UpstreamHost{ | 		&UpstreamHost{ | ||||||
| @ -55,3 +61,12 @@ func TestLeastConnPolicy(t *testing.T) { | |||||||
| 		t.Error("Expected least connection host to be first or second host.") | 		t.Error("Expected least connection host to be first or second host.") | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func TestCustomPolicy(t *testing.T) { | ||||||
|  | 	pool := testPool() | ||||||
|  | 	customPolicy := &customPolicy{} | ||||||
|  | 	h := customPolicy.Select(pool) | ||||||
|  | 	if h != pool[0] { | ||||||
|  | 		t.Error("Expected custom policy host to be the first host.") | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | |||||||
| @ -12,6 +12,8 @@ import ( | |||||||
| 	"github.com/mholt/caddy/config/parse" | 	"github.com/mholt/caddy/config/parse" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | var supportedPolicies map[string]func() Policy = make(map[string]func() Policy) | ||||||
|  | 
 | ||||||
| type staticUpstream struct { | type staticUpstream struct { | ||||||
| 	from   string | 	from   string | ||||||
| 	Hosts  HostPool | 	Hosts  HostPool | ||||||
| @ -53,14 +55,10 @@ func NewStaticUpstreams(c parse.Dispenser) ([]Upstream, error) { | |||||||
| 				if !c.NextArg() { | 				if !c.NextArg() { | ||||||
| 					return upstreams, c.ArgErr() | 					return upstreams, c.ArgErr() | ||||||
| 				} | 				} | ||||||
| 				switch c.Val() { | 
 | ||||||
| 				case "random": | 				if policyCreateFunc, ok := supportedPolicies[c.Val()]; ok { | ||||||
| 					upstream.Policy = &Random{} | 					upstream.Policy = policyCreateFunc() | ||||||
| 				case "round_robin": | 				} else { | ||||||
| 					upstream.Policy = &RoundRobin{} |  | ||||||
| 				case "least_conn": |  | ||||||
| 					upstream.Policy = &LeastConn{} |  | ||||||
| 				default: |  | ||||||
| 					return upstreams, c.ArgErr() | 					return upstreams, c.ArgErr() | ||||||
| 				} | 				} | ||||||
| 			case "fail_timeout": | 			case "fail_timeout": | ||||||
| @ -147,6 +145,11 @@ func NewStaticUpstreams(c parse.Dispenser) ([]Upstream, error) { | |||||||
| 	return upstreams, nil | 	return upstreams, nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | // RegisterPolicy adds a custom policy to the proxy. | ||||||
|  | func RegisterPolicy(name string, policy func() Policy) { | ||||||
|  | 	supportedPolicies[name] = policy | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (u *staticUpstream) From() string { | func (u *staticUpstream) From() string { | ||||||
| 	return u.from | 	return u.from | ||||||
| } | } | ||||||
|  | |||||||
| @ -41,3 +41,13 @@ func TestSelect(t *testing.T) { | |||||||
| 		t.Error("Expected select to not return 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.") | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user