package eacl import ( "crypto/ecdsa" "testing" v2acl "github.com/nspcc-dev/neofs-api-go/v2/acl" crypto "github.com/nspcc-dev/neofs-crypto" "github.com/nspcc-dev/neofs-crypto/test" "github.com/stretchr/testify/require" ) func TestTarget(t *testing.T) { keys := []ecdsa.PublicKey{ test.DecodeKey(1).PublicKey, test.DecodeKey(2).PublicKey, } target := &Target{ role: RoleSystem, keys: keys, } v2 := target.ToV2() require.NotNil(t, v2) require.Equal(t, v2acl.RoleSystem, v2.GetRole()) require.Len(t, v2.GetKeyList(), len(keys)) for i, key := range v2.GetKeyList() { require.Equal(t, key, crypto.MarshalPublicKey(&keys[i])) } newTarget := NewTargetFromV2(v2) require.Equal(t, target, newTarget) t.Run("from nil v2 target", func(t *testing.T) { require.Equal(t, new(Target), NewTargetFromV2(nil)) }) }