forked from TrueCloudLab/neoneo-go
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:
parent
e71cc04c70
commit
7ddb23abe3
1 changed files with 37 additions and 16 deletions
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue