forked from TrueCloudLab/neoneo-go
compiler: add test for codegen
This commit is contained in:
parent
3c7ac7eb95
commit
b68e9591aa
1 changed files with 72 additions and 0 deletions
72
pkg/compiler/codegen_test.go
Normal file
72
pkg/compiler/codegen_test.go
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
package compiler
|
||||||
|
|
||||||
|
import (
|
||||||
|
"go/token"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/CityOfZion/neo-go/pkg/io"
|
||||||
|
"github.com/CityOfZion/neo-go/pkg/vm/opcode"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestConvertToken(t *testing.T) {
|
||||||
|
type testCase struct {
|
||||||
|
name string
|
||||||
|
token token.Token
|
||||||
|
opcode opcode.Opcode
|
||||||
|
}
|
||||||
|
|
||||||
|
testCases := []testCase{
|
||||||
|
{"ADD",
|
||||||
|
token.ADD,
|
||||||
|
opcode.ADD,
|
||||||
|
},
|
||||||
|
{"SUB",
|
||||||
|
token.SUB,
|
||||||
|
opcode.SUB,
|
||||||
|
},
|
||||||
|
{"MUL",
|
||||||
|
token.MUL,
|
||||||
|
opcode.MUL,
|
||||||
|
},
|
||||||
|
{"QUO",
|
||||||
|
token.QUO,
|
||||||
|
opcode.DIV,
|
||||||
|
},
|
||||||
|
{"REM",
|
||||||
|
token.REM,
|
||||||
|
opcode.MOD,
|
||||||
|
},
|
||||||
|
{"ADD_ASSIGN",
|
||||||
|
token.ADD_ASSIGN,
|
||||||
|
opcode.ADD,
|
||||||
|
},
|
||||||
|
{"SUB_ASSIGN",
|
||||||
|
token.SUB_ASSIGN,
|
||||||
|
opcode.SUB,
|
||||||
|
},
|
||||||
|
{"MUL_ASSIGN",
|
||||||
|
token.MUL_ASSIGN,
|
||||||
|
opcode.MUL,
|
||||||
|
},
|
||||||
|
{"QUO_ASSIGN",
|
||||||
|
token.QUO_ASSIGN,
|
||||||
|
opcode.DIV,
|
||||||
|
},
|
||||||
|
{"REM_ASSIGN",
|
||||||
|
token.REM_ASSIGN,
|
||||||
|
opcode.MOD,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tcase := range testCases {
|
||||||
|
t.Run(tcase.name, func(t *testing.T) { eval(t, tcase.token, tcase.opcode) })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func eval(t *testing.T, token token.Token, opcode opcode.Opcode) {
|
||||||
|
codegen := &codegen{prog: io.NewBufBinWriter()}
|
||||||
|
codegen.convertToken(token)
|
||||||
|
readOpcode := codegen.prog.Bytes()
|
||||||
|
assert.Equal(t, []byte{byte(opcode)}, readOpcode)
|
||||||
|
}
|
Loading…
Reference in a new issue