2023-03-10 19:44:28 +00:00
|
|
|
// Copyright (c) Tailscale Inc & AUTHORS
|
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
package ipn
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"tailscale.com/tailcfg"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestCheckFunnelAccess(t *testing.T) {
|
2023-03-11 16:45:40 +00:00
|
|
|
portAttr := "https://tailscale.com/cap/funnel-ports?ports=443,8080-8090,8443,"
|
2023-03-10 19:44:28 +00:00
|
|
|
tests := []struct {
|
2023-03-11 16:45:40 +00:00
|
|
|
port uint16
|
2023-03-10 19:44:28 +00:00
|
|
|
caps []string
|
|
|
|
wantErr bool
|
|
|
|
}{
|
2023-03-11 16:45:40 +00:00
|
|
|
{443, []string{portAttr}, true}, // No "funnel" attribute
|
|
|
|
{443, []string{portAttr, tailcfg.CapabilityWarnFunnelNoInvite}, true},
|
|
|
|
{443, []string{portAttr, tailcfg.CapabilityWarnFunnelNoHTTPS}, true},
|
|
|
|
{443, []string{portAttr, tailcfg.NodeAttrFunnel}, false},
|
|
|
|
{8443, []string{portAttr, tailcfg.NodeAttrFunnel}, false},
|
|
|
|
{8321, []string{portAttr, tailcfg.NodeAttrFunnel}, true},
|
|
|
|
{8083, []string{portAttr, tailcfg.NodeAttrFunnel}, false},
|
|
|
|
{8091, []string{portAttr, tailcfg.NodeAttrFunnel}, true},
|
|
|
|
{3000, []string{portAttr, tailcfg.NodeAttrFunnel}, true},
|
2023-03-10 19:44:28 +00:00
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
2023-03-11 16:45:40 +00:00
|
|
|
err := CheckFunnelAccess(tt.port, tt.caps)
|
2023-03-10 19:44:28 +00:00
|
|
|
switch {
|
|
|
|
case err != nil && tt.wantErr,
|
|
|
|
err == nil && !tt.wantErr:
|
|
|
|
continue
|
|
|
|
case tt.wantErr:
|
|
|
|
t.Fatalf("got no error, want error")
|
|
|
|
case !tt.wantErr:
|
|
|
|
t.Fatalf("got error %v, want no error", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|