vm: fix not failing PUSHBYTES* on short read
Add some tests also. Fixes #361.
This commit is contained in:
parent
450063de7d
commit
a2a8981979
2 changed files with 19 additions and 0 deletions
|
@ -242,6 +242,9 @@ func (v *VM) execute(ctx *Context, op Instruction) {
|
||||||
|
|
||||||
if op >= PUSHBYTES1 && op <= PUSHBYTES75 {
|
if op >= PUSHBYTES1 && op <= PUSHBYTES75 {
|
||||||
b := ctx.readBytes(int(op))
|
b := ctx.readBytes(int(op))
|
||||||
|
if b == nil {
|
||||||
|
panic("failed to read instruction parameter")
|
||||||
|
}
|
||||||
v.estack.PushVal(b)
|
v.estack.PushVal(b)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,6 +60,22 @@ func TestPushBytes1to75(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestPushBytesNoParam(t *testing.T) {
|
||||||
|
prog := make([]byte, 1)
|
||||||
|
prog[0] = byte(PUSHBYTES1)
|
||||||
|
vm := load(prog)
|
||||||
|
vm.Run()
|
||||||
|
assert.Equal(t, true, vm.state.HasFlag(faultState))
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPushBytesShort(t *testing.T) {
|
||||||
|
prog := make([]byte, 10)
|
||||||
|
prog[0] = byte(PUSHBYTES10) // but only 9 left in the `prog`
|
||||||
|
vm := load(prog)
|
||||||
|
vm.Run()
|
||||||
|
assert.Equal(t, true, vm.state.HasFlag(faultState))
|
||||||
|
}
|
||||||
|
|
||||||
func TestPushm1to16(t *testing.T) {
|
func TestPushm1to16(t *testing.T) {
|
||||||
var prog []byte
|
var prog []byte
|
||||||
for i := int(PUSHM1); i <= int(PUSH16); i++ {
|
for i := int(PUSHM1); i <= int(PUSH16); i++ {
|
||||||
|
|
Loading…
Reference in a new issue