This fix tries to fix 261 where proxy upstream parser is not able to parse upstream correctly. Several test cases have also been added to cover the changes and prevent regression in the future. This fix fixes 261. Signed-off-by: Yong Tang <yong.tang.github@outlook.com>
154 lines
2.8 KiB
Go
154 lines
2.8 KiB
Go
package proxy
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/mholt/caddy"
|
|
)
|
|
|
|
func TestHealthCheck(t *testing.T) {
|
|
upstream := &staticUpstream{
|
|
from: "",
|
|
Hosts: testPool(),
|
|
Policy: &Random{},
|
|
Spray: nil,
|
|
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: "miek.nl.",
|
|
IgnoredSubDomains: []string{"download.", "static."}, // closing dot mandatory
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
expected bool
|
|
}{
|
|
{"miek.nl.", true},
|
|
{"download.miek.nl.", false},
|
|
{"static.miek.nl.", false},
|
|
{"blaat.miek.nl.", true},
|
|
}
|
|
|
|
for i, test := range tests {
|
|
isAllowed := upstream.IsAllowedPath(test.name)
|
|
if test.expected != isAllowed {
|
|
t.Errorf("Test %d: expected %v found %v for %s", i+1, test.expected, isAllowed, test.name)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestProxyParse(t *testing.T) {
|
|
tests := []struct {
|
|
inputUpstreams string
|
|
shouldErr bool
|
|
}{
|
|
{
|
|
`proxy . 8.8.8.8:53`,
|
|
false,
|
|
},
|
|
{
|
|
`
|
|
proxy . 8.8.8.8:53 {
|
|
policy round_robin
|
|
}`,
|
|
false,
|
|
},
|
|
{
|
|
`
|
|
proxy . 8.8.8.8:53 {
|
|
fail_timeout 5s
|
|
}`,
|
|
false,
|
|
},
|
|
{
|
|
`
|
|
proxy . 8.8.8.8:53 {
|
|
max_fails 10
|
|
}`,
|
|
false,
|
|
},
|
|
{
|
|
`
|
|
proxy . 8.8.8.8:53 {
|
|
health_check /health:8080
|
|
}`,
|
|
false,
|
|
},
|
|
{
|
|
`
|
|
proxy . 8.8.8.8:53 {
|
|
without without
|
|
}`,
|
|
false,
|
|
},
|
|
{
|
|
`
|
|
proxy . 8.8.8.8:53 {
|
|
except miek.nl example.org
|
|
}`,
|
|
false,
|
|
},
|
|
{
|
|
`
|
|
proxy . 8.8.8.8:53 {
|
|
spray
|
|
}`,
|
|
false,
|
|
},
|
|
{
|
|
`
|
|
proxy . 8.8.8.8:53 {
|
|
error_option
|
|
}`,
|
|
true,
|
|
},
|
|
}
|
|
for i, test := range tests {
|
|
c := caddy.NewTestController("dns", test.inputUpstreams)
|
|
_, err := NewStaticUpstreams(&c.Dispenser)
|
|
if (err != nil) != test.shouldErr {
|
|
t.Errorf("Test %d expected no error, got %v", i+1, err)
|
|
}
|
|
}
|
|
}
|