vm/tests: unmarshal stack items in JSON tests properly

New item types were added in NEO3 and they can be capitalized or not.
This commit is contained in:
Evgenii Stratonikov 2020-05-20 15:48:19 +03:00
parent e71cc04c70
commit 7ddb23abe3

View file

@ -78,14 +78,17 @@ const (
vmStepOut vmUTActionType = "StepOut" vmStepOut vmUTActionType = "StepOut"
vmStepOver vmUTActionType = "StepOver" vmStepOver vmUTActionType = "StepOver"
typeArray vmUTStackItemType = "Array" typeArray vmUTStackItemType = "array"
typeBoolean vmUTStackItemType = "Boolean" typeBoolean vmUTStackItemType = "boolean"
typeByteArray vmUTStackItemType = "ByteArray" typeBuffer vmUTStackItemType = "buffer"
typeInteger vmUTStackItemType = "Integer" typeByteString vmUTStackItemType = "bytestring"
typeInterop vmUTStackItemType = "Interop" typeInteger vmUTStackItemType = "integer"
typeMap vmUTStackItemType = "Map" typeInterop vmUTStackItemType = "interop"
typeString vmUTStackItemType = "String" typeMap vmUTStackItemType = "map"
typeStruct vmUTStackItemType = "Struct" typeNull vmUTStackItemType = "null"
typePointer vmUTStackItemType = "pointer"
typeString vmUTStackItemType = "string"
typeStruct vmUTStackItemType = "struct"
testsDir = "testdata/neo-vm/tests/neo-vm.Tests/Tests/" testsDir = "testdata/neo-vm/tests/neo-vm.Tests/Tests/"
) )
@ -182,6 +185,10 @@ func compareItems(t *testing.T, a, b StackItem) {
default: default:
require.Fail(t, "wrong type") require.Fail(t, "wrong type")
} }
case *PointerItem:
p, ok := b.(*PointerItem)
require.True(t, ok)
require.Equal(t, si.pos, p.pos) // there no script in test files
default: default:
require.Equal(t, a, b) require.Equal(t, a, b)
} }
@ -206,7 +213,7 @@ func compareStacks(t *testing.T, expected []vmUTStackItem, actual *Stack) {
} }
func (v *vmUTStackItem) toStackItem() StackItem { func (v *vmUTStackItem) toStackItem() StackItem {
switch v.Type { switch v.Type.toLower() {
case typeArray: case typeArray:
items := v.Value.([]vmUTStackItem) items := v.Value.([]vmUTStackItem)
result := make([]StackItem, len(items)) result := make([]StackItem, len(items))
@ -229,10 +236,16 @@ func (v *vmUTStackItem) toStackItem() StackItem {
return result return result
case typeInterop: case typeInterop:
panic("not implemented") panic("not implemented")
case typeByteArray: case typeByteString:
return &ByteArrayItem{ return &ByteArrayItem{
v.Value.([]byte), v.Value.([]byte),
} }
case typeBuffer:
return &BufferItem{v.Value.([]byte)}
case typePointer:
return NewPointerItem(v.Value.(int), nil)
case typeNull:
return NullItem{}
case typeBoolean: case typeBoolean:
return &BoolItem{ return &BoolItem{
v.Value.(bool), v.Value.(bool),
@ -251,7 +264,7 @@ func (v *vmUTStackItem) toStackItem() StackItem {
value: result, value: result,
} }
default: default:
panic("invalid type") panic(fmt.Sprintf("invalid type: %s", v.Type))
} }
} }
@ -278,6 +291,10 @@ func execStep(t *testing.T, v *VM, step vmUTStep) {
} }
} }
func (v vmUTStackItemType) toLower() vmUTStackItemType {
return vmUTStackItemType(strings.ToLower(string(v)))
}
func (v *vmUTScript) UnmarshalJSON(data []byte) error { func (v *vmUTScript) UnmarshalJSON(data []byte) error {
var ops []string var ops []string
if err := json.Unmarshal(data, &ops); err != nil { if err := json.Unmarshal(data, &ops); err != nil {
@ -333,14 +350,14 @@ func (v *vmUTStackItem) UnmarshalJSON(data []byte) error {
v.Type = si.Type v.Type = si.Type
switch si.Type { switch typ := si.Type.toLower(); typ {
case typeArray, typeStruct: case typeArray, typeStruct:
var a []vmUTStackItem var a []vmUTStackItem
if err := json.Unmarshal(si.Value, &a); err != nil { if err := json.Unmarshal(si.Value, &a); err != nil {
return err return err
} }
v.Value = a v.Value = a
case typeInteger: case typeInteger, typePointer:
num := new(big.Int) num := new(big.Int)
var a int64 var a int64
var s string var s string
@ -351,20 +368,24 @@ func (v *vmUTStackItem) UnmarshalJSON(data []byte) error {
} else { } else {
panic(fmt.Sprintf("invalid integer: %v", si.Value)) panic(fmt.Sprintf("invalid integer: %v", si.Value))
} }
v.Value = num if typ == typePointer {
v.Value = int(num.Int64())
} else {
v.Value = num
}
case typeBoolean: case typeBoolean:
var b bool var b bool
if err := json.Unmarshal(si.Value, &b); err != nil { if err := json.Unmarshal(si.Value, &b); err != nil {
return err return err
} }
v.Value = b v.Value = b
case typeByteArray: case typeByteString, typeBuffer:
b, err := decodeBytes(si.Value) b, err := decodeBytes(si.Value)
if err != nil { if err != nil {
return err return err
} }
v.Value = b v.Value = b
case typeInterop: case typeInterop, typeNull:
v.Value = nil v.Value = nil
case typeMap: case typeMap:
var m map[string]vmUTStackItem var m map[string]vmUTStackItem