2015-05-03 07:20:36 +02:00
|
|
|
package proxy
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
2015-05-29 00:56:11 +02:00
|
|
|
type customPolicy struct{}
|
|
|
|
|
|
|
|
func (r *customPolicy) Select(pool HostPool) *UpstreamHost {
|
|
|
|
return pool[0]
|
|
|
|
}
|
|
|
|
|
2015-05-03 07:20:36 +02:00
|
|
|
func testPool() HostPool {
|
|
|
|
pool := []*UpstreamHost{
|
2015-10-10 00:35:34 +02:00
|
|
|
{
|
2015-05-03 07:20:36 +02:00
|
|
|
Name: "http://google.com", // this should resolve (healthcheck test)
|
|
|
|
},
|
2015-10-10 00:35:34 +02:00
|
|
|
{
|
2015-05-03 07:20:36 +02:00
|
|
|
Name: "http://shouldnot.resolve", // this shouldn't
|
|
|
|
},
|
2015-10-10 00:35:34 +02:00
|
|
|
{
|
2015-05-03 07:20:36 +02:00
|
|
|
Name: "http://C",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
return HostPool(pool)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRoundRobinPolicy(t *testing.T) {
|
|
|
|
pool := testPool()
|
|
|
|
rrPolicy := &RoundRobin{}
|
|
|
|
h := rrPolicy.Select(pool)
|
|
|
|
// First selected host is 1, because counter starts at 0
|
|
|
|
// and increments before host is selected
|
|
|
|
if h != pool[1] {
|
|
|
|
t.Error("Expected first round robin host to be second host in the pool.")
|
|
|
|
}
|
|
|
|
h = rrPolicy.Select(pool)
|
|
|
|
if h != pool[2] {
|
|
|
|
t.Error("Expected second round robin host to be third host in the pool.")
|
|
|
|
}
|
|
|
|
// mark host as down
|
|
|
|
pool[0].Unhealthy = true
|
|
|
|
h = rrPolicy.Select(pool)
|
|
|
|
if h != pool[1] {
|
|
|
|
t.Error("Expected third round robin host to be first host in the pool.")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestLeastConnPolicy(t *testing.T) {
|
|
|
|
pool := testPool()
|
|
|
|
lcPolicy := &LeastConn{}
|
|
|
|
pool[0].Conns = 10
|
|
|
|
pool[1].Conns = 10
|
|
|
|
h := lcPolicy.Select(pool)
|
|
|
|
if h != pool[2] {
|
|
|
|
t.Error("Expected least connection host to be third host.")
|
|
|
|
}
|
|
|
|
pool[2].Conns = 100
|
|
|
|
h = lcPolicy.Select(pool)
|
|
|
|
if h != pool[0] && h != pool[1] {
|
|
|
|
t.Error("Expected least connection host to be first or second host.")
|
|
|
|
}
|
|
|
|
}
|
2015-05-29 00:56:11 +02:00
|
|
|
|
|
|
|
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.")
|
|
|
|
}
|
|
|
|
}
|