596774ce5b
Allow to use public keys and N3 wallet accounts instead. Signed-off-by: Evgenii Stratonikov <evgeniy@nspcc.ru>
165 lines
3.2 KiB
Go
165 lines
3.2 KiB
Go
package owner_test
|
|
|
|
import (
|
|
"crypto/ecdsa"
|
|
"testing"
|
|
|
|
"github.com/mr-tron/base58"
|
|
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
|
"github.com/nspcc-dev/neo-go/pkg/util/slice"
|
|
"github.com/nspcc-dev/neo-go/pkg/wallet"
|
|
"github.com/nspcc-dev/neofs-api-go/v2/refs"
|
|
. "github.com/nspcc-dev/neofs-sdk-go/owner"
|
|
ownertest "github.com/nspcc-dev/neofs-sdk-go/owner/test"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestIDV2(t *testing.T) {
|
|
id := ownertest.ID()
|
|
|
|
idV2 := id.ToV2()
|
|
|
|
require.Equal(t, id, NewIDFromV2(idV2))
|
|
}
|
|
|
|
func TestID_Valid(t *testing.T) {
|
|
id := ownertest.ID()
|
|
require.True(t, id.Valid())
|
|
|
|
val := id.ToV2().GetValue()
|
|
|
|
t.Run("invalid prefix", func(t *testing.T) {
|
|
val := slice.Copy(val)
|
|
val[0] ^= 0xFF
|
|
|
|
id := ownertest.IDFromBytes(val)
|
|
require.False(t, id.Valid())
|
|
})
|
|
t.Run("invalid size", func(t *testing.T) {
|
|
val := val[:NEO3WalletSize-1]
|
|
|
|
id := ownertest.IDFromBytes(val)
|
|
require.False(t, id.Valid())
|
|
})
|
|
t.Run("invalid checksum", func(t *testing.T) {
|
|
val := slice.Copy(val)
|
|
val[NEO3WalletSize-1] ^= 0xFF
|
|
|
|
id := ownertest.IDFromBytes(val)
|
|
require.False(t, id.Valid())
|
|
})
|
|
}
|
|
|
|
func TestNewIDFromN3Account(t *testing.T) {
|
|
acc, err := wallet.NewAccount()
|
|
require.NoError(t, err)
|
|
|
|
id := NewIDFromN3Account(acc)
|
|
require.Equal(t, id.String(), acc.Address)
|
|
}
|
|
|
|
func TestNewIDFromPublicKey(t *testing.T) {
|
|
p, err := keys.NewPrivateKey()
|
|
require.NoError(t, err)
|
|
|
|
id := NewIDFromPublicKey((*ecdsa.PublicKey)(p.PublicKey()))
|
|
require.Equal(t, id.String(), p.Address())
|
|
}
|
|
|
|
func TestID_Parse(t *testing.T) {
|
|
t.Run("should parse successful", func(t *testing.T) {
|
|
acc, err := wallet.NewAccount()
|
|
require.NoError(t, err)
|
|
|
|
eid := NewIDFromN3Account(acc)
|
|
aid := NewID()
|
|
|
|
require.NoError(t, aid.Parse(eid.String()))
|
|
require.Equal(t, eid, aid)
|
|
})
|
|
|
|
t.Run("should failure on parse", func(t *testing.T) {
|
|
cs := []byte{1, 2, 3, 4, 5, 6}
|
|
str := base58.Encode(cs)
|
|
cid := NewID()
|
|
|
|
require.Error(t, cid.Parse(str))
|
|
})
|
|
}
|
|
|
|
func TestIDEncoding(t *testing.T) {
|
|
id := ownertest.ID()
|
|
|
|
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.IDFromBytes(data1)
|
|
|
|
require.True(t, id1.Equal(
|
|
ownertest.IDFromBytes(data2),
|
|
))
|
|
|
|
require.False(t, id1.Equal(
|
|
ownertest.IDFromBytes(data3),
|
|
))
|
|
}
|
|
|
|
func TestNewIDFromV2(t *testing.T) {
|
|
t.Run("from nil", func(t *testing.T) {
|
|
var x *refs.OwnerID
|
|
|
|
require.Nil(t, NewIDFromV2(x))
|
|
})
|
|
}
|
|
|
|
func TestID_ToV2(t *testing.T) {
|
|
t.Run("nil", func(t *testing.T) {
|
|
var x *ID
|
|
|
|
require.Nil(t, x.ToV2())
|
|
})
|
|
}
|
|
|
|
func TestID_String(t *testing.T) {
|
|
t.Run("nil", func(t *testing.T) {
|
|
id := NewID()
|
|
|
|
require.Empty(t, id.String())
|
|
})
|
|
}
|
|
|
|
func TestNewID(t *testing.T) {
|
|
t.Run("default values", func(t *testing.T) {
|
|
id := NewID()
|
|
|
|
// convert to v2 message
|
|
idV2 := id.ToV2()
|
|
|
|
require.Nil(t, idV2.GetValue())
|
|
})
|
|
}
|