mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-11 01:20:37 +00:00
parent
f78e3fb290
commit
0b2e9312af
4 changed files with 76 additions and 1 deletions
|
@ -54,6 +54,12 @@ func (a *ABI) IsValid() error {
|
||||||
if len(a.Methods) == 0 {
|
if len(a.Methods) == 0 {
|
||||||
return errors.New("ABI contains no methods")
|
return errors.New("ABI contains no methods")
|
||||||
}
|
}
|
||||||
|
for i := range a.Events {
|
||||||
|
err := a.Events[i].IsValid()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,7 @@ package manifest
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"sort"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/vm/stackitem"
|
"github.com/nspcc-dev/neo-go/pkg/vm/stackitem"
|
||||||
)
|
)
|
||||||
|
@ -12,6 +13,29 @@ type Event struct {
|
||||||
Parameters []Parameter `json:"parameters"`
|
Parameters []Parameter `json:"parameters"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// IsValid checks Event consistency and correctness.
|
||||||
|
func (e *Event) IsValid() error {
|
||||||
|
if e.Name == "" {
|
||||||
|
return errors.New("empty or absent name")
|
||||||
|
}
|
||||||
|
if len(e.Parameters) > 1 {
|
||||||
|
paramNames := make([]string, len(e.Parameters))
|
||||||
|
for i := range e.Parameters {
|
||||||
|
paramNames[i] = e.Parameters[i].Name
|
||||||
|
}
|
||||||
|
sort.Strings(paramNames)
|
||||||
|
for i := range paramNames {
|
||||||
|
if i == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if paramNames[i] == paramNames[i-1] {
|
||||||
|
return errors.New("duplicate parameter name")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// ToStackItem converts Event to stackitem.Item.
|
// ToStackItem converts Event to stackitem.Item.
|
||||||
func (e *Event) ToStackItem() stackitem.Item {
|
func (e *Event) ToStackItem() stackitem.Item {
|
||||||
params := make([]stackitem.Item, len(e.Parameters))
|
params := make([]stackitem.Item, len(e.Parameters))
|
||||||
|
|
|
@ -9,6 +9,29 @@ import (
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func TestEventIsValid(t *testing.T) {
|
||||||
|
e := Event{}
|
||||||
|
require.Error(t, e.IsValid())
|
||||||
|
|
||||||
|
e.Name = "some"
|
||||||
|
require.NoError(t, e.IsValid())
|
||||||
|
|
||||||
|
e.Parameters = make([]Parameter, 0)
|
||||||
|
require.NoError(t, e.IsValid())
|
||||||
|
|
||||||
|
e.Parameters = append(e.Parameters, NewParameter("p1", smartcontract.BoolType))
|
||||||
|
require.NoError(t, e.IsValid())
|
||||||
|
|
||||||
|
e.Parameters = append(e.Parameters, NewParameter("p2", smartcontract.IntegerType))
|
||||||
|
require.NoError(t, e.IsValid())
|
||||||
|
|
||||||
|
e.Parameters = append(e.Parameters, NewParameter("p3", smartcontract.IntegerType))
|
||||||
|
require.NoError(t, e.IsValid())
|
||||||
|
|
||||||
|
e.Parameters = append(e.Parameters, NewParameter("p1", smartcontract.IntegerType))
|
||||||
|
require.Error(t, e.IsValid())
|
||||||
|
}
|
||||||
|
|
||||||
func TestEvent_ToStackItemFromStackItem(t *testing.T) {
|
func TestEvent_ToStackItemFromStackItem(t *testing.T) {
|
||||||
m := &Event{
|
m := &Event{
|
||||||
Name: "mur",
|
Name: "mur",
|
||||||
|
|
|
@ -121,10 +121,32 @@ func TestIsValid(t *testing.T) {
|
||||||
Parameters: []Parameter{},
|
Parameters: []Parameter{},
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("valid, no groups", func(t *testing.T) {
|
t.Run("valid, no groups/events", func(t *testing.T) {
|
||||||
require.NoError(t, m.IsValid(contractHash))
|
require.NoError(t, m.IsValid(contractHash))
|
||||||
})
|
})
|
||||||
|
|
||||||
|
m.ABI.Events = append(m.ABI.Events, Event{
|
||||||
|
Name: "itHappened",
|
||||||
|
Parameters: []Parameter{},
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("valid, with events", func(t *testing.T) {
|
||||||
|
require.NoError(t, m.IsValid(contractHash))
|
||||||
|
})
|
||||||
|
|
||||||
|
m.ABI.Events = append(m.ABI.Events, Event{
|
||||||
|
Name: "itHappened",
|
||||||
|
Parameters: []Parameter{
|
||||||
|
NewParameter("qwerty", smartcontract.IntegerType),
|
||||||
|
NewParameter("qwerty", smartcontract.IntegerType),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("invalid, bad event", func(t *testing.T) {
|
||||||
|
require.Error(t, m.IsValid(contractHash))
|
||||||
|
})
|
||||||
|
m.ABI.Events = m.ABI.Events[:1]
|
||||||
|
|
||||||
t.Run("with groups", func(t *testing.T) {
|
t.Run("with groups", func(t *testing.T) {
|
||||||
m.Groups = make([]Group, 3)
|
m.Groups = make([]Group, 3)
|
||||||
pks := make([]*keys.PrivateKey, 3)
|
pks := make([]*keys.PrivateKey, 3)
|
||||||
|
|
Loading…
Reference in a new issue