2022-01-21 13:52:19 +01:00
|
|
|
package peer
|
|
|
|
|
|
|
|
import (
|
2024-05-07 18:50:34 +02:00
|
|
|
"context"
|
2024-06-20 18:17:30 +02:00
|
|
|
"os"
|
2022-01-21 13:52:19 +01:00
|
|
|
"sync"
|
|
|
|
"testing"
|
|
|
|
"time"
|
2023-03-03 19:49:18 +01:00
|
|
|
|
|
|
|
"github.com/magiconair/properties/assert"
|
2024-06-20 18:17:30 +02:00
|
|
|
log "github.com/sirupsen/logrus"
|
2023-03-03 19:49:18 +01:00
|
|
|
|
2023-07-26 14:00:47 +02:00
|
|
|
"github.com/netbirdio/netbird/client/internal/stdnet"
|
|
|
|
"github.com/netbirdio/netbird/client/internal/wgproxy"
|
2023-03-03 19:49:18 +01:00
|
|
|
"github.com/netbirdio/netbird/iface"
|
2024-06-20 18:17:30 +02:00
|
|
|
relayClient "github.com/netbirdio/netbird/relay/client"
|
|
|
|
"github.com/netbirdio/netbird/util"
|
2022-01-21 13:52:19 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
var connConf = ConnConfig{
|
2024-06-19 09:40:43 +02:00
|
|
|
Key: "LLHf3Ma6z6mdLbriAJbqhX7+nM/B71lgw2+91q3LfhU=",
|
|
|
|
LocalKey: "RRHf3Ma6z6mdLbriAJbqhX7+nM/B71lgw2+91q3LfhU=",
|
|
|
|
Timeout: time.Second,
|
|
|
|
LocalWgPort: 51820,
|
|
|
|
ICEConfig: ICEConfig{
|
|
|
|
InterfaceBlackList: nil,
|
|
|
|
},
|
2022-01-21 13:52:19 +01:00
|
|
|
}
|
|
|
|
|
2024-06-20 18:17:30 +02:00
|
|
|
func TestMain(m *testing.M) {
|
|
|
|
_ = util.InitLog("trace", "console")
|
|
|
|
code := m.Run()
|
|
|
|
os.Exit(code)
|
|
|
|
}
|
|
|
|
|
2022-06-04 20:15:41 +02:00
|
|
|
func TestNewConn_interfaceFilter(t *testing.T) {
|
|
|
|
ignore := []string{iface.WgInterfaceDefault, "tun0", "zt", "ZeroTier", "utun", "wg", "ts",
|
|
|
|
"Tailscale", "tailscale"}
|
|
|
|
|
2023-04-13 17:00:01 +02:00
|
|
|
filter := stdnet.InterfaceFilter(ignore)
|
2022-06-04 20:15:41 +02:00
|
|
|
|
|
|
|
for _, s := range ignore {
|
|
|
|
assert.Equal(t, filter(s), false)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2022-01-21 13:52:19 +01:00
|
|
|
func TestConn_GetKey(t *testing.T) {
|
2024-06-22 15:33:10 +02:00
|
|
|
wgProxyFactory := wgproxy.NewFactory(context.Background(), false, connConf.LocalWgPort)
|
2023-07-26 14:00:47 +02:00
|
|
|
defer func() {
|
|
|
|
_ = wgProxyFactory.Free()
|
|
|
|
}()
|
2024-06-19 09:40:43 +02:00
|
|
|
conn, err := NewConn(context.Background(), connConf, nil, wgProxyFactory, nil, nil, nil)
|
2022-01-21 13:52:19 +01:00
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
got := conn.GetKey()
|
|
|
|
|
|
|
|
assert.Equal(t, got, connConf.Key, "they should be equal")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestConn_OnRemoteOffer(t *testing.T) {
|
2024-06-22 15:33:10 +02:00
|
|
|
wgProxyFactory := wgproxy.NewFactory(context.Background(), false, connConf.LocalWgPort)
|
2023-07-26 14:00:47 +02:00
|
|
|
defer func() {
|
|
|
|
_ = wgProxyFactory.Free()
|
|
|
|
}()
|
2024-06-19 09:40:43 +02:00
|
|
|
conn, err := NewConn(context.Background(), connConf, NewRecorder("https://mgm"), wgProxyFactory, nil, nil, nil)
|
2022-01-21 13:52:19 +01:00
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
wg := sync.WaitGroup{}
|
|
|
|
wg.Add(2)
|
|
|
|
go func() {
|
2024-06-19 09:40:43 +02:00
|
|
|
<-conn.handshaker.remoteOffersCh
|
2022-01-21 13:52:19 +01:00
|
|
|
wg.Done()
|
|
|
|
}()
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
for {
|
2022-09-02 19:33:35 +02:00
|
|
|
accepted := conn.OnRemoteOffer(OfferAnswer{
|
|
|
|
IceCredentials: IceCredentials{
|
|
|
|
UFrag: "test",
|
|
|
|
Pwd: "test",
|
|
|
|
},
|
|
|
|
WgListenPort: 0,
|
|
|
|
Version: "",
|
2022-01-21 13:52:19 +01:00
|
|
|
})
|
|
|
|
if accepted {
|
|
|
|
wg.Done()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
wg.Wait()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestConn_OnRemoteAnswer(t *testing.T) {
|
2024-06-22 15:33:10 +02:00
|
|
|
wgProxyFactory := wgproxy.NewFactory(context.Background(), false, connConf.LocalWgPort)
|
2023-07-26 14:00:47 +02:00
|
|
|
defer func() {
|
|
|
|
_ = wgProxyFactory.Free()
|
|
|
|
}()
|
2024-06-19 09:40:43 +02:00
|
|
|
conn, err := NewConn(context.Background(), connConf, NewRecorder("https://mgm"), wgProxyFactory, nil, nil, nil)
|
2022-01-21 13:52:19 +01:00
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
wg := sync.WaitGroup{}
|
|
|
|
wg.Add(2)
|
|
|
|
go func() {
|
2024-06-19 09:40:43 +02:00
|
|
|
<-conn.handshaker.remoteAnswerCh
|
2022-01-21 13:52:19 +01:00
|
|
|
wg.Done()
|
|
|
|
}()
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
for {
|
2022-09-02 19:33:35 +02:00
|
|
|
accepted := conn.OnRemoteAnswer(OfferAnswer{
|
|
|
|
IceCredentials: IceCredentials{
|
|
|
|
UFrag: "test",
|
|
|
|
Pwd: "test",
|
|
|
|
},
|
|
|
|
WgListenPort: 0,
|
|
|
|
Version: "",
|
2022-01-21 13:52:19 +01:00
|
|
|
})
|
|
|
|
if accepted {
|
|
|
|
wg.Done()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
wg.Wait()
|
|
|
|
}
|
|
|
|
func TestConn_Status(t *testing.T) {
|
2024-06-22 15:33:10 +02:00
|
|
|
wgProxyFactory := wgproxy.NewFactory(context.Background(), false, connConf.LocalWgPort)
|
2023-07-26 14:00:47 +02:00
|
|
|
defer func() {
|
|
|
|
_ = wgProxyFactory.Free()
|
|
|
|
}()
|
2024-06-19 09:40:43 +02:00
|
|
|
conn, err := NewConn(context.Background(), connConf, NewRecorder("https://mgm"), wgProxyFactory, nil, nil, nil)
|
2022-01-21 13:52:19 +01:00
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
tables := []struct {
|
2024-06-19 09:40:43 +02:00
|
|
|
name string
|
|
|
|
statusIce ConnStatus
|
|
|
|
statusRelay ConnStatus
|
|
|
|
want ConnStatus
|
2022-01-21 13:52:19 +01:00
|
|
|
}{
|
2024-06-19 09:40:43 +02:00
|
|
|
{"StatusConnected", StatusConnected, StatusConnected, StatusConnected},
|
|
|
|
{"StatusDisconnected", StatusDisconnected, StatusDisconnected, StatusDisconnected},
|
|
|
|
{"StatusConnecting", StatusConnecting, StatusConnecting, StatusConnecting},
|
|
|
|
{"StatusConnectingIce", StatusConnecting, StatusDisconnected, StatusConnecting},
|
|
|
|
{"StatusConnectingIceAlternative", StatusConnecting, StatusConnected, StatusConnected},
|
|
|
|
{"StatusConnectingRelay", StatusDisconnected, StatusConnecting, StatusConnecting},
|
|
|
|
{"StatusConnectingRelayAlternative", StatusConnected, StatusConnecting, StatusConnected},
|
2022-01-21 13:52:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, table := range tables {
|
|
|
|
t.Run(table.name, func(t *testing.T) {
|
2024-06-19 09:40:43 +02:00
|
|
|
conn.statusICE = table.statusIce
|
|
|
|
conn.statusRelay = table.statusRelay
|
2022-01-21 13:52:19 +01:00
|
|
|
|
|
|
|
got := conn.Status()
|
|
|
|
assert.Equal(t, got, table.want, "they should be equal")
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2024-06-20 18:17:30 +02:00
|
|
|
|
|
|
|
func TestConn_Switch(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
|
2024-07-08 15:05:29 +02:00
|
|
|
wgProxyFactory := wgproxy.NewFactory(ctx, false, connConf.LocalWgPort)
|
2024-06-20 18:17:30 +02:00
|
|
|
connConfAlice := ConnConfig{
|
|
|
|
Key: "LLHf3Ma6z6mdLbriAJbqhX7+nM/B71lgw2+91q3LfhU=",
|
|
|
|
LocalKey: "RRHf3Ma6z6mdLbriAJbqhX7+nM/B71lgw2+91q3LfhU=",
|
|
|
|
Timeout: time.Second,
|
|
|
|
LocalWgPort: 51820,
|
|
|
|
ICEConfig: ICEConfig{
|
|
|
|
InterfaceBlackList: nil,
|
|
|
|
},
|
|
|
|
WgConfig: WgConfig{
|
|
|
|
WgListenPort: 51820,
|
|
|
|
RemoteKey: "LLHf3Ma6z6mdLbriAJbqhX7+nM/B71lgw2+91q3LfhU=",
|
|
|
|
AllowedIps: "172.16.254.0/16",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
relayManagerAlice := relayClient.NewManager(ctx, "127.0.0.1:1234", connConf.LocalKey)
|
|
|
|
connAlice, err := NewConn(ctx, connConfAlice, NewRecorder("https://mgm"), wgProxyFactory, nil, nil, relayManagerAlice)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("failed to create conn: %v", err)
|
|
|
|
}
|
|
|
|
connAlice.Open()
|
|
|
|
|
|
|
|
connConfbob := ConnConfig{
|
|
|
|
Key: "RRHf3Ma6z6mdLbriAJbqhX7+nM/B71lgw2+91q3LfhU=",
|
|
|
|
LocalKey: "LLHf3Ma6z6mdLbriAJbqhX7+nM/B71lgw2+91q3LfhU=",
|
|
|
|
Timeout: time.Second,
|
|
|
|
LocalWgPort: 51820,
|
|
|
|
ICEConfig: ICEConfig{
|
|
|
|
InterfaceBlackList: nil,
|
|
|
|
},
|
|
|
|
WgConfig: WgConfig{
|
|
|
|
WgListenPort: 51820,
|
|
|
|
RemoteKey: "RRHf3Ma6z6mdLbriAJbqhX7+nM/B71lgw2+91q3LfhU=",
|
|
|
|
AllowedIps: "172.16.254.0/16",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
relayManagerBob := relayClient.NewManager(ctx, "127.0.0.1:1234", connConf.LocalKey)
|
|
|
|
connBob, err := NewConn(ctx, connConfbob, NewRecorder("https://mgm"), wgProxyFactory, nil, nil, relayManagerBob)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("failed to create conn: %v", err)
|
|
|
|
}
|
|
|
|
connBob.Open()
|
|
|
|
}
|