forked from TrueCloudLab/neoneo-go
core: adjust System.Contract.IsStandard interop
Part of #1055. It should check not only stored contracts, but also interop context script container in case if it's a transaction.
This commit is contained in:
parent
d2f452c240
commit
1a5fb01e61
2 changed files with 43 additions and 4 deletions
|
@ -486,8 +486,17 @@ func contractIsStandard(ic *interop.Context, v *vm.VM) error {
|
||||||
}
|
}
|
||||||
var result bool
|
var result bool
|
||||||
cs, _ := ic.DAO.GetContractState(u)
|
cs, _ := ic.DAO.GetContractState(u)
|
||||||
if cs == nil || vm.IsStandardContract(cs.Script) {
|
if cs != nil {
|
||||||
result = true
|
result = vm.IsStandardContract(cs.Script)
|
||||||
|
} else {
|
||||||
|
if tx, ok := ic.Container.(*transaction.Transaction); ok {
|
||||||
|
for _, witness := range tx.Scripts {
|
||||||
|
if witness.ScriptHash() == u {
|
||||||
|
result = vm.IsStandardContract(witness.VerificationScript)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
v.Estack().PushVal(result)
|
v.Estack().PushVal(result)
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -5,8 +5,10 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/nspcc-dev/dbft/crypto"
|
"github.com/nspcc-dev/dbft/crypto"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/config/netmode"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/core/interop/runtime"
|
"github.com/nspcc-dev/neo-go/pkg/core/interop/runtime"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/core/state"
|
"github.com/nspcc-dev/neo-go/pkg/core/state"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/core/transaction"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/crypto/hash"
|
"github.com/nspcc-dev/neo-go/pkg/crypto/hash"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/util"
|
"github.com/nspcc-dev/neo-go/pkg/util"
|
||||||
|
@ -157,7 +159,35 @@ func TestContractIsStandard(t *testing.T) {
|
||||||
v, ic, chain := createVM(t)
|
v, ic, chain := createVM(t)
|
||||||
defer chain.Close()
|
defer chain.Close()
|
||||||
|
|
||||||
t.Run("True", func(t *testing.T) {
|
t.Run("contract not stored", func(t *testing.T) {
|
||||||
|
priv, err := keys.NewPrivateKey()
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
pub := priv.PublicKey()
|
||||||
|
tx := transaction.New(netmode.TestNet, []byte{1, 2, 3}, 1)
|
||||||
|
tx.Scripts = []transaction.Witness{
|
||||||
|
{
|
||||||
|
InvocationScript: []byte{1, 2, 3},
|
||||||
|
VerificationScript: pub.GetVerificationScript(),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
ic.Container = tx
|
||||||
|
|
||||||
|
t.Run("true", func(t *testing.T) {
|
||||||
|
v.Estack().PushVal(pub.GetScriptHash().BytesBE())
|
||||||
|
require.NoError(t, contractIsStandard(ic, v))
|
||||||
|
require.True(t, v.Estack().Pop().Bool())
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("false", func(t *testing.T) {
|
||||||
|
tx.Scripts[0].VerificationScript = []byte{9, 8, 7}
|
||||||
|
v.Estack().PushVal(pub.GetScriptHash().BytesBE())
|
||||||
|
require.NoError(t, contractIsStandard(ic, v))
|
||||||
|
require.False(t, v.Estack().Pop().Bool())
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("contract stored, true", func(t *testing.T) {
|
||||||
priv, err := keys.NewPrivateKey()
|
priv, err := keys.NewPrivateKey()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
@ -169,7 +199,7 @@ func TestContractIsStandard(t *testing.T) {
|
||||||
require.NoError(t, contractIsStandard(ic, v))
|
require.NoError(t, contractIsStandard(ic, v))
|
||||||
require.True(t, v.Estack().Pop().Bool())
|
require.True(t, v.Estack().Pop().Bool())
|
||||||
})
|
})
|
||||||
t.Run("False", func(t *testing.T) {
|
t.Run("contract stored, false", func(t *testing.T) {
|
||||||
script := []byte{byte(opcode.PUSHT)}
|
script := []byte{byte(opcode.PUSHT)}
|
||||||
require.NoError(t, ic.DAO.PutContractState(&state.Contract{ID: 24, Script: script}))
|
require.NoError(t, ic.DAO.PutContractState(&state.Contract{ID: 24, Script: script}))
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue