forked from TrueCloudLab/frostfs-api-go
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>
101 lines
2 KiB
Go
101 lines
2 KiB
Go
package owner_test
|
|
|
|
import (
|
|
"strconv"
|
|
"testing"
|
|
|
|
"github.com/mr-tron/base58"
|
|
. "github.com/nspcc-dev/neofs-api-go/pkg/owner"
|
|
ownertest "github.com/nspcc-dev/neofs-api-go/pkg/owner/test"
|
|
"github.com/nspcc-dev/neofs-crypto/test"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestIDV2(t *testing.T) {
|
|
id := ownertest.Generate()
|
|
|
|
idV2 := id.ToV2()
|
|
|
|
require.Equal(t, id, NewIDFromV2(idV2))
|
|
}
|
|
|
|
func TestNewIDFromNeo3Wallet(t *testing.T) {
|
|
wallet, err := NEO3WalletFromPublicKey(&test.DecodeKey(1).PublicKey)
|
|
require.NoError(t, err)
|
|
|
|
id := NewIDFromNeo3Wallet(wallet)
|
|
require.Equal(t, id.ToV2().GetValue(), wallet.Bytes())
|
|
}
|
|
|
|
func TestID_Parse(t *testing.T) {
|
|
t.Run("should parse successful", func(t *testing.T) {
|
|
for i := 0; i < 10; i++ {
|
|
j := i
|
|
t.Run(strconv.Itoa(j), func(t *testing.T) {
|
|
wallet, err := NEO3WalletFromPublicKey(&test.DecodeKey(j).PublicKey)
|
|
require.NoError(t, err)
|
|
|
|
eid := NewIDFromNeo3Wallet(wallet)
|
|
aid := NewID()
|
|
|
|
require.NoError(t, aid.Parse(eid.String()))
|
|
require.Equal(t, eid, aid)
|
|
})
|
|
}
|
|
})
|
|
|
|
t.Run("should failure on parse", func(t *testing.T) {
|
|
for i := 0; i < 10; i++ {
|
|
j := i
|
|
t.Run(strconv.Itoa(j), func(t *testing.T) {
|
|
cs := []byte{1, 2, 3, 4, 5, byte(j)}
|
|
str := base58.Encode(cs)
|
|
cid := NewID()
|
|
|
|
require.Error(t, cid.Parse(str))
|
|
})
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestIDEncoding(t *testing.T) {
|
|
id := ownertest.Generate()
|
|
|
|
t.Run("binary", func(t *testing.T) {
|
|
data, err := id.Marshal()
|
|
require.NoError(t, err)
|
|
|
|
id2 := NewID()
|
|
require.NoError(t, id2.Unmarshal(data))
|
|
|
|
require.Equal(t, id, id2)
|
|
})
|
|
|
|
t.Run("json", func(t *testing.T) {
|
|
data, err := id.MarshalJSON()
|
|
require.NoError(t, err)
|
|
|
|
a2 := NewID()
|
|
require.NoError(t, a2.UnmarshalJSON(data))
|
|
|
|
require.Equal(t, id, a2)
|
|
})
|
|
}
|
|
|
|
func TestID_Equal(t *testing.T) {
|
|
var (
|
|
data1 = []byte{1, 2, 3}
|
|
data2 = data1
|
|
data3 = append(data1, 255)
|
|
)
|
|
|
|
id1 := ownertest.GenerateFromBytes(data1)
|
|
|
|
require.True(t, id1.Equal(
|
|
ownertest.GenerateFromBytes(data2),
|
|
))
|
|
|
|
require.False(t, id1.Equal(
|
|
ownertest.GenerateFromBytes(data3),
|
|
))
|
|
}
|