2024-02-22 17:22:43 +01:00
|
|
|
package posture
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/netip"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
|
|
|
nbpeer "github.com/netbirdio/netbird/management/server/peer"
|
|
|
|
)
|
|
|
|
|
2024-02-27 11:59:48 +01:00
|
|
|
func TestPeerNetworkRangeCheck_Check(t *testing.T) {
|
2024-02-22 17:22:43 +01:00
|
|
|
tests := []struct {
|
|
|
|
name string
|
2024-02-27 11:59:48 +01:00
|
|
|
check PeerNetworkRangeCheck
|
2024-02-22 17:22:43 +01:00
|
|
|
peer nbpeer.Peer
|
|
|
|
wantErr bool
|
|
|
|
isValid bool
|
|
|
|
}{
|
|
|
|
{
|
2024-02-27 11:59:48 +01:00
|
|
|
name: "Peer networks range matches the allowed range",
|
|
|
|
check: PeerNetworkRangeCheck{
|
2024-02-22 17:22:43 +01:00
|
|
|
Action: CheckActionAllow,
|
|
|
|
Ranges: []netip.Prefix{
|
|
|
|
netip.MustParsePrefix("192.168.0.0/24"),
|
|
|
|
netip.MustParsePrefix("10.0.0.0/8"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
peer: nbpeer.Peer{
|
|
|
|
Meta: nbpeer.PeerSystemMeta{
|
|
|
|
NetworkAddresses: []nbpeer.NetworkAddress{
|
|
|
|
{
|
|
|
|
NetIP: netip.MustParsePrefix("192.168.0.123/24"),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
NetIP: netip.MustParsePrefix("fe80::6089:eaff:fe0c:232f/64"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: false,
|
|
|
|
isValid: true,
|
|
|
|
},
|
|
|
|
{
|
2024-02-27 11:59:48 +01:00
|
|
|
name: "Peer networks range doesn't matches the allowed range",
|
|
|
|
check: PeerNetworkRangeCheck{
|
2024-02-22 17:22:43 +01:00
|
|
|
Action: CheckActionAllow,
|
|
|
|
Ranges: []netip.Prefix{
|
|
|
|
netip.MustParsePrefix("192.168.0.0/24"),
|
|
|
|
netip.MustParsePrefix("10.0.0.0/8"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
peer: nbpeer.Peer{
|
|
|
|
Meta: nbpeer.PeerSystemMeta{
|
|
|
|
NetworkAddresses: []nbpeer.NetworkAddress{
|
|
|
|
{
|
|
|
|
NetIP: netip.MustParsePrefix("198.19.249.3/24"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: false,
|
|
|
|
isValid: false,
|
|
|
|
},
|
|
|
|
{
|
2024-02-27 11:59:48 +01:00
|
|
|
name: "Peer with no network range in the allow range",
|
|
|
|
check: PeerNetworkRangeCheck{
|
2024-02-22 17:22:43 +01:00
|
|
|
Action: CheckActionAllow,
|
|
|
|
Ranges: []netip.Prefix{
|
|
|
|
netip.MustParsePrefix("192.168.0.0/16"),
|
|
|
|
netip.MustParsePrefix("10.0.0.0/8"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
peer: nbpeer.Peer{},
|
|
|
|
wantErr: true,
|
|
|
|
isValid: false,
|
|
|
|
},
|
|
|
|
{
|
2024-02-27 11:59:48 +01:00
|
|
|
name: "Peer networks range matches the denied range",
|
|
|
|
check: PeerNetworkRangeCheck{
|
2024-02-22 17:22:43 +01:00
|
|
|
Action: CheckActionDeny,
|
|
|
|
Ranges: []netip.Prefix{
|
|
|
|
netip.MustParsePrefix("192.168.0.0/24"),
|
|
|
|
netip.MustParsePrefix("10.0.0.0/8"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
peer: nbpeer.Peer{
|
|
|
|
Meta: nbpeer.PeerSystemMeta{
|
|
|
|
NetworkAddresses: []nbpeer.NetworkAddress{
|
|
|
|
{
|
|
|
|
NetIP: netip.MustParsePrefix("192.168.0.123/24"),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
NetIP: netip.MustParsePrefix("fe80::6089:eaff:fe0c:232f/64"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: false,
|
|
|
|
isValid: false,
|
|
|
|
},
|
|
|
|
{
|
2024-02-27 11:59:48 +01:00
|
|
|
name: "Peer networks range doesn't matches the denied range",
|
|
|
|
check: PeerNetworkRangeCheck{
|
2024-02-22 17:22:43 +01:00
|
|
|
Action: CheckActionDeny,
|
|
|
|
Ranges: []netip.Prefix{
|
|
|
|
netip.MustParsePrefix("192.168.0.0/24"),
|
|
|
|
netip.MustParsePrefix("10.0.0.0/8"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
peer: nbpeer.Peer{
|
|
|
|
Meta: nbpeer.PeerSystemMeta{
|
|
|
|
NetworkAddresses: []nbpeer.NetworkAddress{
|
|
|
|
{
|
|
|
|
NetIP: netip.MustParsePrefix("198.19.249.3/24"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: false,
|
|
|
|
isValid: true,
|
|
|
|
},
|
|
|
|
{
|
2024-02-27 11:59:48 +01:00
|
|
|
name: "Peer with no networks range in the denied range",
|
|
|
|
check: PeerNetworkRangeCheck{
|
2024-02-22 17:22:43 +01:00
|
|
|
Action: CheckActionDeny,
|
|
|
|
Ranges: []netip.Prefix{
|
|
|
|
netip.MustParsePrefix("192.168.0.0/16"),
|
|
|
|
netip.MustParsePrefix("10.0.0.0/8"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
peer: nbpeer.Peer{},
|
|
|
|
wantErr: true,
|
|
|
|
isValid: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
isValid, err := tt.check.Check(tt.peer)
|
|
|
|
if tt.wantErr {
|
|
|
|
assert.Error(t, err)
|
|
|
|
} else {
|
|
|
|
assert.NoError(t, err)
|
|
|
|
}
|
|
|
|
assert.Equal(t, tt.isValid, isValid)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2024-06-13 13:24:24 +02:00
|
|
|
|
|
|
|
func TestNetworkCheck_Validate(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
check PeerNetworkRangeCheck
|
|
|
|
expectedError bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "Valid network range",
|
|
|
|
check: PeerNetworkRangeCheck{
|
|
|
|
Action: CheckActionAllow,
|
|
|
|
Ranges: []netip.Prefix{
|
|
|
|
netip.MustParsePrefix("192.168.1.0/24"),
|
|
|
|
netip.MustParsePrefix("10.0.0.0/8"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedError: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Invalid empty network range",
|
|
|
|
check: PeerNetworkRangeCheck{
|
|
|
|
Action: CheckActionDeny,
|
|
|
|
Ranges: []netip.Prefix{},
|
|
|
|
},
|
|
|
|
expectedError: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Invalid check action",
|
|
|
|
check: PeerNetworkRangeCheck{
|
|
|
|
Action: "unknownAction",
|
|
|
|
Ranges: []netip.Prefix{
|
|
|
|
netip.MustParsePrefix("10.0.0.0/8"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedError: true,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range testCases {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
err := tc.check.Validate()
|
|
|
|
if tc.expectedError {
|
|
|
|
assert.Error(t, err)
|
|
|
|
} else {
|
|
|
|
assert.NoError(t, err)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|