mirror of
https://github.com/jsiebens/ionscale.git
synced 2026-03-31 15:07:49 +01:00
41 lines
1.1 KiB
Go
41 lines
1.1 KiB
Go
package tests
|
|
|
|
import (
|
|
"github.com/jsiebens/ionscale/pkg/defaults"
|
|
ionscalev1 "github.com/jsiebens/ionscale/pkg/gen/ionscale/v1"
|
|
"github.com/jsiebens/ionscale/tests/sc"
|
|
"github.com/jsiebens/ionscale/tests/tsn"
|
|
"github.com/stretchr/testify/require"
|
|
"testing"
|
|
)
|
|
|
|
func TestACL_PeersShouldBeRemovedWhenNoMatchingACLRuleIsAvailable(t *testing.T) {
|
|
sc.Run(t, func(s *sc.Scenario) {
|
|
tailnet := s.CreateTailnet()
|
|
clientKey := s.CreateAuthKey(tailnet.Id, true, "tag:client")
|
|
serverKey := s.CreateAuthKey(tailnet.Id, true, "tag:server")
|
|
|
|
client1 := s.NewTailscaleNode()
|
|
client2 := s.NewTailscaleNode()
|
|
server := s.NewTailscaleNode()
|
|
|
|
require.NoError(t, client1.Up(clientKey))
|
|
require.NoError(t, client2.Up(clientKey))
|
|
require.NoError(t, server.Up(serverKey))
|
|
require.NoError(t, server.WaitFor(tsn.PeerCount(2)))
|
|
|
|
policy := defaults.DefaultACLPolicy()
|
|
policy.Acls = []*ionscalev1.ACL{
|
|
{
|
|
Action: "accept",
|
|
Src: []string{"tag:server"},
|
|
Dst: []string{"tag:server:*"},
|
|
},
|
|
}
|
|
|
|
s.SetACLPolicy(tailnet.Id, policy)
|
|
|
|
require.NoError(t, server.WaitFor(tsn.PeerCount(0)))
|
|
})
|
|
}
|