65080c8b69
Remove usage of deprecated of `container.ID` and `token.SessionToken` code elements. Replace using of custom message generators with the ones provided by packages. Replace string comparison with `Equal` method call. Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
138 lines
3.1 KiB
Go
138 lines
3.1 KiB
Go
package eacl_test
|
|
|
|
import (
|
|
"crypto/sha256"
|
|
"testing"
|
|
|
|
"github.com/nspcc-dev/neofs-api-go/pkg"
|
|
"github.com/nspcc-dev/neofs-api-go/pkg/acl/eacl"
|
|
cidtest "github.com/nspcc-dev/neofs-api-go/pkg/container/id/test"
|
|
sessiontest "github.com/nspcc-dev/neofs-api-go/pkg/session/test"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestTable(t *testing.T) {
|
|
var (
|
|
v pkg.Version
|
|
)
|
|
|
|
sha := sha256.Sum256([]byte("container id"))
|
|
id := cidtest.GenerateWithChecksum(sha)
|
|
|
|
v.SetMajor(3)
|
|
v.SetMinor(2)
|
|
|
|
table := eacl.NewTable()
|
|
table.SetVersion(v)
|
|
table.SetCID(id)
|
|
table.AddRecord(eacl.CreateRecord(eacl.ActionAllow, eacl.OperationPut))
|
|
|
|
v2 := table.ToV2()
|
|
require.NotNil(t, v2)
|
|
require.Equal(t, uint32(3), v2.GetVersion().GetMajor())
|
|
require.Equal(t, uint32(2), v2.GetVersion().GetMinor())
|
|
require.Equal(t, sha[:], v2.GetContainerID().GetValue())
|
|
require.Len(t, v2.GetRecords(), 1)
|
|
|
|
newTable := eacl.NewTableFromV2(v2)
|
|
require.Equal(t, table, newTable)
|
|
|
|
t.Run("new from nil v2 table", func(t *testing.T) {
|
|
require.Equal(t, new(eacl.Table), eacl.NewTableFromV2(nil))
|
|
})
|
|
|
|
t.Run("create table", func(t *testing.T) {
|
|
id := cidtest.Generate()
|
|
|
|
table := eacl.CreateTable(*id)
|
|
require.Equal(t, id, table.CID())
|
|
require.Equal(t, *pkg.SDKVersion(), table.Version())
|
|
})
|
|
}
|
|
|
|
func TestTable_AddRecord(t *testing.T) {
|
|
records := []*eacl.Record{
|
|
eacl.CreateRecord(eacl.ActionDeny, eacl.OperationDelete),
|
|
eacl.CreateRecord(eacl.ActionAllow, eacl.OperationPut),
|
|
}
|
|
|
|
table := eacl.NewTable()
|
|
for _, record := range records {
|
|
table.AddRecord(record)
|
|
}
|
|
|
|
require.Equal(t, records, table.Records())
|
|
}
|
|
|
|
func TestRecordEncoding(t *testing.T) {
|
|
tab := eacl.NewTable()
|
|
tab.AddRecord(
|
|
eacl.CreateRecord(eacl.ActionDeny, eacl.OperationHead),
|
|
)
|
|
|
|
t.Run("binary", func(t *testing.T) {
|
|
data, err := tab.Marshal()
|
|
require.NoError(t, err)
|
|
|
|
tab2 := eacl.NewTable()
|
|
require.NoError(t, tab2.Unmarshal(data))
|
|
|
|
require.Equal(t, tab, tab2)
|
|
})
|
|
|
|
t.Run("json", func(t *testing.T) {
|
|
data, err := tab.MarshalJSON()
|
|
require.NoError(t, err)
|
|
|
|
r2 := eacl.NewTable()
|
|
require.NoError(t, r2.UnmarshalJSON(data))
|
|
|
|
require.Equal(t, tab, r2)
|
|
})
|
|
}
|
|
|
|
func TestTable_SessionToken(t *testing.T) {
|
|
tok := sessiontest.Generate()
|
|
|
|
table := eacl.NewTable()
|
|
table.SetSessionToken(tok)
|
|
|
|
require.Equal(t, tok, table.SessionToken())
|
|
}
|
|
|
|
func TestTable_Signature(t *testing.T) {
|
|
sig := pkg.NewSignature()
|
|
sig.SetKey([]byte{1, 2, 3})
|
|
sig.SetSign([]byte{4, 5, 6})
|
|
|
|
table := eacl.NewTable()
|
|
table.SetSignature(sig)
|
|
|
|
require.Equal(t, sig, table.Signature())
|
|
}
|
|
|
|
func TestTable_ToV2(t *testing.T) {
|
|
t.Run("nil", func(t *testing.T) {
|
|
var x *eacl.Table
|
|
|
|
require.Nil(t, x.ToV2())
|
|
})
|
|
|
|
t.Run("default values", func(t *testing.T) {
|
|
table := eacl.NewTable()
|
|
|
|
// check initial values
|
|
require.Equal(t, *pkg.SDKVersion(), table.Version())
|
|
require.Nil(t, table.Records())
|
|
require.Nil(t, table.CID())
|
|
require.Nil(t, table.SessionToken())
|
|
require.Nil(t, table.Signature())
|
|
|
|
// convert to v2 message
|
|
tableV2 := table.ToV2()
|
|
|
|
require.Equal(t, pkg.SDKVersion().ToV2(), tableV2.GetVersion())
|
|
require.Nil(t, tableV2.GetRecords())
|
|
require.Nil(t, tableV2.GetContainerID())
|
|
})
|
|
}
|