mirror of https://github.com/tailscale/tailscale/
feature/relayserver: wire up profile/prefs changes (#15714)
The relay server is still permanently disabled until node attribute changes are wired up in a future commit. Updates tailscale/corp#27502 Signed-off-by: Jordan Whited <jordan@tailscale.com>pull/15721/head
parent
9666c2e700
commit
92027d7ae0
@ -0,0 +1,126 @@
|
|||||||
|
// Copyright (c) Tailscale Inc & AUTHORS
|
||||||
|
// SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
|
||||||
|
package relayserver
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"tailscale.com/ipn"
|
||||||
|
"tailscale.com/net/udprelay"
|
||||||
|
"tailscale.com/types/key"
|
||||||
|
"tailscale.com/types/ptr"
|
||||||
|
)
|
||||||
|
|
||||||
|
type fakeRelayServer struct{}
|
||||||
|
|
||||||
|
func (f *fakeRelayServer) Close() error { return nil }
|
||||||
|
|
||||||
|
func (f *fakeRelayServer) AllocateEndpoint(_, _ key.DiscoPublic) (udprelay.ServerEndpoint, error) {
|
||||||
|
return udprelay.ServerEndpoint{}, errors.New("fake relay server")
|
||||||
|
}
|
||||||
|
|
||||||
|
func Test_extension_profileStateChanged(t *testing.T) {
|
||||||
|
prefsWithPortOne := ipn.Prefs{RelayServerPort: ptr.To(1)}
|
||||||
|
prefsWithNilPort := ipn.Prefs{RelayServerPort: nil}
|
||||||
|
|
||||||
|
type fields struct {
|
||||||
|
server relayServer
|
||||||
|
port *int
|
||||||
|
}
|
||||||
|
type args struct {
|
||||||
|
prefs ipn.PrefsView
|
||||||
|
sameNode bool
|
||||||
|
}
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
fields fields
|
||||||
|
args args
|
||||||
|
wantPort *int
|
||||||
|
wantNilServer bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "no changes non-nil server",
|
||||||
|
fields: fields{
|
||||||
|
server: &fakeRelayServer{},
|
||||||
|
port: ptr.To(1),
|
||||||
|
},
|
||||||
|
args: args{
|
||||||
|
prefs: prefsWithPortOne.View(),
|
||||||
|
sameNode: true,
|
||||||
|
},
|
||||||
|
wantPort: ptr.To(1),
|
||||||
|
wantNilServer: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "prefs port nil",
|
||||||
|
fields: fields{
|
||||||
|
server: &fakeRelayServer{},
|
||||||
|
port: ptr.To(1),
|
||||||
|
},
|
||||||
|
args: args{
|
||||||
|
prefs: prefsWithNilPort.View(),
|
||||||
|
sameNode: true,
|
||||||
|
},
|
||||||
|
wantPort: nil,
|
||||||
|
wantNilServer: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "prefs port changed",
|
||||||
|
fields: fields{
|
||||||
|
server: &fakeRelayServer{},
|
||||||
|
port: ptr.To(2),
|
||||||
|
},
|
||||||
|
args: args{
|
||||||
|
prefs: prefsWithPortOne.View(),
|
||||||
|
sameNode: true,
|
||||||
|
},
|
||||||
|
wantPort: ptr.To(1),
|
||||||
|
wantNilServer: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "sameNode false",
|
||||||
|
fields: fields{
|
||||||
|
server: &fakeRelayServer{},
|
||||||
|
port: ptr.To(1),
|
||||||
|
},
|
||||||
|
args: args{
|
||||||
|
prefs: prefsWithPortOne.View(),
|
||||||
|
sameNode: false,
|
||||||
|
},
|
||||||
|
wantPort: ptr.To(1),
|
||||||
|
wantNilServer: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "prefs port non-nil extension port nil",
|
||||||
|
fields: fields{
|
||||||
|
server: nil,
|
||||||
|
port: nil,
|
||||||
|
},
|
||||||
|
args: args{
|
||||||
|
prefs: prefsWithPortOne.View(),
|
||||||
|
sameNode: false,
|
||||||
|
},
|
||||||
|
wantPort: ptr.To(1),
|
||||||
|
wantNilServer: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
e := &extension{
|
||||||
|
port: tt.fields.port,
|
||||||
|
server: tt.fields.server,
|
||||||
|
}
|
||||||
|
e.profileStateChanged(ipn.LoginProfileView{}, tt.args.prefs, tt.args.sameNode)
|
||||||
|
if tt.wantNilServer != (e.server == nil) {
|
||||||
|
t.Errorf("wantNilServer: %v != (e.server == nil): %v", tt.wantNilServer, e.server == nil)
|
||||||
|
}
|
||||||
|
if (tt.wantPort == nil) != (e.port == nil) {
|
||||||
|
t.Errorf("(tt.wantPort == nil): %v != (e.port == nil): %v", tt.wantPort == nil, e.port == nil)
|
||||||
|
} else if tt.wantPort != nil && *tt.wantPort != *e.port {
|
||||||
|
t.Errorf("wantPort: %d != *e.port: %d", *tt.wantPort, *e.port)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue