Merge eth-go repository into go-ethereum
mist, etheruem have been moved to cmd/
This commit is contained in:
11
tests/helper/common.go
Normal file
11
tests/helper/common.go
Normal file
@ -0,0 +1,11 @@
|
||||
package helper
|
||||
|
||||
import "github.com/ethereum/go-ethereum/ethutil"
|
||||
|
||||
func FromHex(h string) []byte {
|
||||
if ethutil.IsHex(h) {
|
||||
h = h[2:]
|
||||
}
|
||||
|
||||
return ethutil.Hex2Bytes(h)
|
||||
}
|
19
tests/helper/init.go
Normal file
19
tests/helper/init.go
Normal file
@ -0,0 +1,19 @@
|
||||
package helper
|
||||
|
||||
import (
|
||||
"log"
|
||||
"os"
|
||||
|
||||
"github.com/ethereum/go-ethereum/ethlog"
|
||||
"github.com/ethereum/go-ethereum/ethutil"
|
||||
)
|
||||
|
||||
var Logger ethlog.LogSystem
|
||||
var Log = ethlog.NewLogger("TEST")
|
||||
|
||||
func init() {
|
||||
Logger = ethlog.NewStdLogSystem(os.Stdout, log.LstdFlags, ethlog.InfoLevel)
|
||||
ethlog.AddLogSystem(Logger)
|
||||
|
||||
ethutil.ReadConfig(".ethtest", "/tmp/ethtest", "")
|
||||
}
|
42
tests/helper/readers.go
Normal file
42
tests/helper/readers.go
Normal file
@ -0,0 +1,42 @@
|
||||
package helper
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"io"
|
||||
"io/ioutil"
|
||||
"net/http"
|
||||
"os"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func readJSON(t *testing.T, reader io.Reader, value interface{}) {
|
||||
data, err := ioutil.ReadAll(reader)
|
||||
err = json.Unmarshal(data, &value)
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
}
|
||||
|
||||
func CreateHttpTests(t *testing.T, uri string, value interface{}) {
|
||||
resp, err := http.Get(uri)
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
|
||||
return
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
readJSON(t, resp.Body, value)
|
||||
}
|
||||
|
||||
func CreateFileTests(t *testing.T, fn string, value interface{}) {
|
||||
file, err := os.Open(fn)
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
|
||||
return
|
||||
}
|
||||
defer file.Close()
|
||||
|
||||
readJSON(t, file, value)
|
||||
}
|
31
tests/helper/trie.go
Normal file
31
tests/helper/trie.go
Normal file
@ -0,0 +1,31 @@
|
||||
package helper
|
||||
|
||||
import "github.com/ethereum/go-ethereum/ethtrie"
|
||||
|
||||
type MemDatabase struct {
|
||||
db map[string][]byte
|
||||
}
|
||||
|
||||
func NewMemDatabase() (*MemDatabase, error) {
|
||||
db := &MemDatabase{db: make(map[string][]byte)}
|
||||
return db, nil
|
||||
}
|
||||
func (db *MemDatabase) Put(key []byte, value []byte) {
|
||||
db.db[string(key)] = value
|
||||
}
|
||||
func (db *MemDatabase) Get(key []byte) ([]byte, error) {
|
||||
return db.db[string(key)], nil
|
||||
}
|
||||
func (db *MemDatabase) Delete(key []byte) error {
|
||||
delete(db.db, string(key))
|
||||
return nil
|
||||
}
|
||||
func (db *MemDatabase) Print() {}
|
||||
func (db *MemDatabase) Close() {}
|
||||
func (db *MemDatabase) LastKnownTD() []byte { return nil }
|
||||
|
||||
func NewTrie() *ethtrie.Trie {
|
||||
db, _ := NewMemDatabase()
|
||||
|
||||
return ethtrie.New(db, "")
|
||||
}
|
67
tests/helper/vm.go
Normal file
67
tests/helper/vm.go
Normal file
@ -0,0 +1,67 @@
|
||||
package helper
|
||||
|
||||
import (
|
||||
"math/big"
|
||||
|
||||
"github.com/ethereum/go-ethereum/ethstate"
|
||||
"github.com/ethereum/go-ethereum/ethutil"
|
||||
"github.com/ethereum/go-ethereum/vm"
|
||||
)
|
||||
|
||||
type Env struct {
|
||||
state *ethstate.State
|
||||
|
||||
origin []byte
|
||||
parent []byte
|
||||
coinbase []byte
|
||||
|
||||
number *big.Int
|
||||
time int64
|
||||
difficulty *big.Int
|
||||
gasLimit *big.Int
|
||||
}
|
||||
|
||||
func NewEnv(state *ethstate.State) *Env {
|
||||
return &Env{
|
||||
state: state,
|
||||
}
|
||||
}
|
||||
|
||||
func NewEnvFromMap(state *ethstate.State, envValues map[string]string, exeValues map[string]string) *Env {
|
||||
env := NewEnv(state)
|
||||
|
||||
env.origin = ethutil.Hex2Bytes(exeValues["caller"])
|
||||
env.parent = ethutil.Hex2Bytes(envValues["previousHash"])
|
||||
env.coinbase = ethutil.Hex2Bytes(envValues["currentCoinbase"])
|
||||
env.number = ethutil.Big(envValues["currentNumber"])
|
||||
env.time = ethutil.Big(envValues["currentTimestamp"]).Int64()
|
||||
env.difficulty = ethutil.Big(envValues["currentDifficulty"])
|
||||
env.gasLimit = ethutil.Big(envValues["currentGasLimit"])
|
||||
|
||||
return env
|
||||
}
|
||||
|
||||
func (self *Env) Origin() []byte { return self.origin }
|
||||
func (self *Env) BlockNumber() *big.Int { return self.number }
|
||||
func (self *Env) PrevHash() []byte { return self.parent }
|
||||
func (self *Env) Coinbase() []byte { return self.coinbase }
|
||||
func (self *Env) Time() int64 { return self.time }
|
||||
func (self *Env) Difficulty() *big.Int { return self.difficulty }
|
||||
func (self *Env) BlockHash() []byte { return nil }
|
||||
func (self *Env) State() *ethstate.State { return self.state }
|
||||
func (self *Env) GasLimit() *big.Int { return self.gasLimit }
|
||||
func (self *Env) Transfer(from, to vm.Account, amount *big.Int) error {
|
||||
return vm.Transfer(from, to, amount)
|
||||
}
|
||||
|
||||
func RunVm(state *ethstate.State, env, exec map[string]string) ([]byte, *big.Int, error) {
|
||||
address := FromHex(exec["address"])
|
||||
caller := state.GetOrNewStateObject(FromHex(exec["caller"]))
|
||||
|
||||
evm := vm.New(NewEnvFromMap(state, env, exec), vm.DebugVmTy)
|
||||
execution := vm.NewExecution(evm, address, FromHex(exec["data"]), ethutil.Big(exec["gas"]), ethutil.Big(exec["gasPrice"]), ethutil.Big(exec["value"]))
|
||||
execution.SkipTransfer = true
|
||||
ret, err := execution.Exec(address, caller)
|
||||
|
||||
return ret, execution.Gas, err
|
||||
}
|
Reference in New Issue
Block a user