Fixed remote Arithmetic tests
This commit is contained in:
@ -4,12 +4,15 @@ import (
|
||||
"encoding/json"
|
||||
"io/ioutil"
|
||||
"net/http"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func CreateTests(uri string, value interface{}) error {
|
||||
func CreateTests(t *testing.T, uri string, value interface{}) {
|
||||
resp, err := http.Get(uri)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
t.Error(err)
|
||||
|
||||
return
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
@ -17,8 +20,6 @@ func CreateTests(uri string, value interface{}) error {
|
||||
|
||||
err = json.Unmarshal(data, &value)
|
||||
if err != nil {
|
||||
return err
|
||||
t.Error(err)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
@ -8,8 +8,11 @@ import (
|
||||
"github.com/ethereum/eth-go/ethutil"
|
||||
)
|
||||
|
||||
var Logger ethlog.LogSystem
|
||||
|
||||
func init() {
|
||||
ethlog.AddLogSystem(ethlog.NewStdLogSystem(os.Stdout, log.LstdFlags, ethlog.LogLevel(4)))
|
||||
Logger = ethlog.NewStdLogSystem(os.Stdout, log.LstdFlags, ethlog.LogLevel(4))
|
||||
ethlog.AddLogSystem(Logger)
|
||||
|
||||
ethutil.ReadConfig(".ethtest", "/tmp/ethtest", "")
|
||||
}
|
||||
|
@ -1,7 +1,6 @@
|
||||
package helper
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"math/big"
|
||||
|
||||
"github.com/ethereum/eth-go/ethstate"
|
||||
@ -51,16 +50,13 @@ func (self *Env) BlockHash() []byte { return nil }
|
||||
// This is likely to fail if anything ever gets looked up in the state trie :-)
|
||||
func (self *Env) State() *ethstate.State { return ethstate.New(ethtrie.New(nil, "")) }
|
||||
|
||||
func RunVm(state *ethstate.State, env, exec map[string]string) ([]byte, *big.Int) {
|
||||
func RunVm(state *ethstate.State, env, exec map[string]string) ([]byte, *big.Int, error) {
|
||||
caller := state.NewStateObject(ethutil.Hex2Bytes(exec["caller"]))
|
||||
callee := state.GetStateObject(ethutil.Hex2Bytes(exec["address"]))
|
||||
closure := ethvm.NewClosure(nil, caller, callee, callee.Code, ethutil.Big(exec["gas"]), ethutil.Big(exec["gasPrice"]))
|
||||
|
||||
vm := ethvm.New(NewEnvFromMap(state, env, exec), ethvm.DebugVmTy)
|
||||
ret, _, e := closure.Call(vm, nil)
|
||||
if e != nil {
|
||||
fmt.Println(e)
|
||||
}
|
||||
|
||||
return ret, closure.Gas
|
||||
return ret, closure.Gas, e
|
||||
}
|
||||
|
@ -2,7 +2,6 @@ package ethvm
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"log"
|
||||
"testing"
|
||||
|
||||
"github.com/ethereum/eth-go/ethstate"
|
||||
@ -40,12 +39,9 @@ type VmTest struct {
|
||||
Pre map[string]Account
|
||||
}
|
||||
|
||||
func TestRemote(t *testing.T) {
|
||||
func RunVmTest(url string, t *testing.T) {
|
||||
tests := make(map[string]VmTest)
|
||||
err := helper.CreateTests("https://raw.githubusercontent.com/ethereum/tests/master/vmtests/vmSha3Test.json", &tests)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
helper.CreateTests(t, url, &tests)
|
||||
|
||||
for name, test := range tests {
|
||||
state := ethstate.New(helper.NewTrie())
|
||||
@ -54,7 +50,10 @@ func TestRemote(t *testing.T) {
|
||||
state.SetStateObject(obj)
|
||||
}
|
||||
|
||||
ret, gas := helper.RunVm(state, test.Env, test.Exec)
|
||||
ret, gas, err := helper.RunVm(state, test.Env, test.Exec)
|
||||
if err != nil {
|
||||
t.Errorf("%s's execution failed. %v\n", name, err)
|
||||
}
|
||||
|
||||
rexp := helper.FromHex(test.Out)
|
||||
if bytes.Compare(rexp, ret) != 0 {
|
||||
@ -79,3 +78,17 @@ func TestRemote(t *testing.T) {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// I've created a new function for each tests so it's easier to identify where the problem lies if any of them fail.
|
||||
func TestVMSha3(t *testing.T) {
|
||||
helper.Logger.SetLogLevel(0)
|
||||
defer helper.Logger.SetLogLevel(4)
|
||||
|
||||
const url = "https://raw.githubusercontent.com/ethereum/tests/master/vmtests/vmSha3Test.json"
|
||||
RunVmTest(url, t)
|
||||
}
|
||||
|
||||
func TestVMArithmetic(t *testing.T) {
|
||||
const url = "https://raw.githubusercontent.com/ethereum/tests/master/vmtests/vmArithmeticTest.json"
|
||||
RunVmTest(url, t)
|
||||
}
|
||||
|
Reference in New Issue
Block a user