blob: 1f31cec1bbb4b6c81684843f7dccc947485a8e5b [file] [log] [blame]
package mirko
import (
"net"
"net/http"
"testing"
"k8s.io/client-go/kubernetes"
)
// TestHTTPRemoteClient exercises GetHTTPRemoteClient.
func TestHTTPRemoteClient(t *testing.T) {
for i, te := range []struct {
// k8s is whether GetHTTPRemoteClient should see itself as running in
// production.
k8s bool
r *http.Request
wantIP net.IP
wantPort uint16
}{
// 0: No headers set, outside cluseter - should work as expected.
{false, &http.Request{RemoteAddr: "1.2.3.4:1234", Header: map[string][]string{}}, net.IPv4(1, 2, 3, 4), 1234},
// 1: No headers set, in cluseter - should fail.
{true, &http.Request{RemoteAddr: "1.2.3.4:1234", Header: map[string][]string{}}, nil, 0},
// 2: Headers set, outside cluster - should parse request, not headers.
{false, &http.Request{RemoteAddr: "1.2.3.4:1234", Header: map[string][]string{
"Hscloud-Nic-Source-Ip": []string{"2.3.4.5"},
"Hscloud-Nic-Source-Port": []string{"2345"},
}}, net.IPv4(1, 2, 3, 4), 1234},
// 3: Headers set, in cluster - should parse headers, not request.
{true, &http.Request{RemoteAddr: "1.2.3.4:1234", Header: map[string][]string{
"Hscloud-Nic-Source-Ip": []string{"2.3.4.5"},
"Hscloud-Nic-Source-Port": []string{"2345"},
}}, net.IPv4(2, 3, 4, 5), 2345},
// 4: Test IPv6 parsing.
{false, &http.Request{RemoteAddr: "[2a0d:eb00::42]:1234", Header: map[string][]string{}},
net.IP([]byte{0x2a, 0x0d, 0xeb, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x42}), 1234},
// 5: Test broken IPv6.
{false, &http.Request{RemoteAddr: "2a0d:eb00::42:1234", Header: map[string][]string{}}, nil, 0},
// 6: Test broken IPv6.
{false, &http.Request{RemoteAddr: "2a0d:eb00::42", Header: map[string][]string{}}, nil, 0},
// 7: Test broken IPv6.
{false, &http.Request{RemoteAddr: "2a0d:80", Header: map[string][]string{}}, nil, 0},
// 8: Test broken port.
{false, &http.Request{RemoteAddr: "1.2.3.4", Header: map[string][]string{}}, nil, 0},
// 9: Test broken port.
{false, &http.Request{RemoteAddr: "1.2.3.4:0", Header: map[string][]string{}}, nil, 0},
} {
kubernetesCSMu.Lock()
if te.k8s {
kubernetesCS = &kubernetes.Clientset{}
} else {
kubernetesCS = nil
}
kubernetesCSValid = true
kubernetesCSMu.Unlock()
gotIP, gotPort, err := GetHTTPRemoteClient(te.r)
if err == nil {
if want, got := te.wantIP, gotIP; !want.Equal(got) {
t.Errorf("%d: wanted IP %v, got %v", i, want, got)
}
if want, got := te.wantPort, gotPort; want != got {
t.Errorf("%d: wanted port %d, got %d", i, want, got)
}
} else {
if te.wantIP != nil || te.wantPort != 0 {
t.Errorf("%d: wanted %v %d, got failure", i, te.wantIP, te.wantPort)
}
}
}
}