stackitem: introduce Convertible interface
We have a lot of native contract types that are converted to stack items before serialization, then deserialized as stack items and converted back to regular structures. stackitem.Convertible allows to remove a lot of repetitive io.Serializable code. This also introduces to/from converter in testserdes which unfortunately required to change util tests to avoid circular references.
This commit is contained in:
parent
2d993d0da5
commit
aab18c3083
23 changed files with 223 additions and 339 deletions
|
@ -1,21 +1,22 @@
|
|||
package util
|
||||
package util_test
|
||||
|
||||
import (
|
||||
"encoding/hex"
|
||||
"testing"
|
||||
|
||||
"github.com/nspcc-dev/neo-go/internal/testserdes"
|
||||
"github.com/nspcc-dev/neo-go/pkg/util"
|
||||
"github.com/stretchr/testify/assert"
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
func TestUint160UnmarshalJSON(t *testing.T) {
|
||||
str := "0263c1de100292813b5e075e585acc1bae963b2d"
|
||||
expected, err := Uint160DecodeStringLE(str)
|
||||
expected, err := util.Uint160DecodeStringLE(str)
|
||||
assert.NoError(t, err)
|
||||
|
||||
// UnmarshalJSON decodes hex-strings
|
||||
var u1, u2 Uint160
|
||||
var u1, u2 util.Uint160
|
||||
|
||||
assert.NoError(t, u1.UnmarshalJSON([]byte(`"`+str+`"`)))
|
||||
assert.True(t, expected.Equals(u1))
|
||||
|
@ -27,25 +28,25 @@ func TestUint160UnmarshalJSON(t *testing.T) {
|
|||
|
||||
func TestUInt160DecodeString(t *testing.T) {
|
||||
hexStr := "2d3b96ae1bcc5a585e075e3b81920210dec16302"
|
||||
val, err := Uint160DecodeStringBE(hexStr)
|
||||
val, err := util.Uint160DecodeStringBE(hexStr)
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, hexStr, val.String())
|
||||
|
||||
valLE, err := Uint160DecodeStringLE(hexStr)
|
||||
valLE, err := util.Uint160DecodeStringLE(hexStr)
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, val, valLE.Reverse())
|
||||
|
||||
_, err = Uint160DecodeStringBE(hexStr[1:])
|
||||
_, err = util.Uint160DecodeStringBE(hexStr[1:])
|
||||
assert.Error(t, err)
|
||||
|
||||
_, err = Uint160DecodeStringLE(hexStr[1:])
|
||||
_, err = util.Uint160DecodeStringLE(hexStr[1:])
|
||||
assert.Error(t, err)
|
||||
|
||||
hexStr = "zz3b96ae1bcc5a585e075e3b81920210dec16302"
|
||||
_, err = Uint160DecodeStringBE(hexStr)
|
||||
_, err = util.Uint160DecodeStringBE(hexStr)
|
||||
assert.Error(t, err)
|
||||
|
||||
_, err = Uint160DecodeStringLE(hexStr)
|
||||
_, err = util.Uint160DecodeStringLE(hexStr)
|
||||
assert.Error(t, err)
|
||||
}
|
||||
|
||||
|
@ -54,18 +55,18 @@ func TestUint160DecodeBytes(t *testing.T) {
|
|||
b, err := hex.DecodeString(hexStr)
|
||||
require.NoError(t, err)
|
||||
|
||||
val, err := Uint160DecodeBytesBE(b)
|
||||
val, err := util.Uint160DecodeBytesBE(b)
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, hexStr, val.String())
|
||||
|
||||
valLE, err := Uint160DecodeBytesLE(b)
|
||||
valLE, err := util.Uint160DecodeBytesLE(b)
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, val, valLE.Reverse())
|
||||
|
||||
_, err = Uint160DecodeBytesLE(b[1:])
|
||||
_, err = util.Uint160DecodeBytesLE(b[1:])
|
||||
assert.Error(t, err)
|
||||
|
||||
_, err = Uint160DecodeBytesBE(b[1:])
|
||||
_, err = util.Uint160DecodeBytesBE(b[1:])
|
||||
assert.Error(t, err)
|
||||
}
|
||||
|
||||
|
@ -73,10 +74,10 @@ func TestUInt160Equals(t *testing.T) {
|
|||
a := "2d3b96ae1bcc5a585e075e3b81920210dec16302"
|
||||
b := "4d3b96ae1bcc5a585e075e3b81920210dec16302"
|
||||
|
||||
ua, err := Uint160DecodeStringBE(a)
|
||||
ua, err := util.Uint160DecodeStringBE(a)
|
||||
require.NoError(t, err)
|
||||
|
||||
ub, err := Uint160DecodeStringBE(b)
|
||||
ub, err := util.Uint160DecodeStringBE(b)
|
||||
require.NoError(t, err)
|
||||
assert.False(t, ua.Equals(ub), "%s and %s cannot be equal", ua, ub)
|
||||
assert.True(t, ua.Equals(ua), "%s and %s must be equal", ua, ua)
|
||||
|
@ -86,11 +87,11 @@ func TestUInt160Less(t *testing.T) {
|
|||
a := "2d3b96ae1bcc5a585e075e3b81920210dec16302"
|
||||
b := "2d3b96ae1bcc5a585e075e3b81920210dec16303"
|
||||
|
||||
ua, err := Uint160DecodeStringBE(a)
|
||||
ua, err := util.Uint160DecodeStringBE(a)
|
||||
assert.Nil(t, err)
|
||||
ua2, err := Uint160DecodeStringBE(a)
|
||||
ua2, err := util.Uint160DecodeStringBE(a)
|
||||
assert.Nil(t, err)
|
||||
ub, err := Uint160DecodeStringBE(b)
|
||||
ub, err := util.Uint160DecodeStringBE(b)
|
||||
assert.Nil(t, err)
|
||||
assert.Equal(t, true, ua.Less(ub))
|
||||
assert.Equal(t, false, ua.Less(ua2))
|
||||
|
@ -101,7 +102,7 @@ func TestUInt160String(t *testing.T) {
|
|||
hexStr := "b28427088a3729b2536d10122960394e8be6721f"
|
||||
hexRevStr := "1f72e68b4e39602912106d53b229378a082784b2"
|
||||
|
||||
val, err := Uint160DecodeStringBE(hexStr)
|
||||
val, err := util.Uint160DecodeStringBE(hexStr)
|
||||
assert.Nil(t, err)
|
||||
|
||||
assert.Equal(t, hexStr, val.String())
|
||||
|
@ -110,7 +111,7 @@ func TestUInt160String(t *testing.T) {
|
|||
|
||||
func TestUint160_Reverse(t *testing.T) {
|
||||
hexStr := "b28427088a3729b2536d10122960394e8be6721f"
|
||||
val, err := Uint160DecodeStringBE(hexStr)
|
||||
val, err := util.Uint160DecodeStringBE(hexStr)
|
||||
|
||||
require.NoError(t, err)
|
||||
assert.Equal(t, hexStr, val.Reverse().StringLE())
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue