2014-02-24 11:10:45 +00:00
|
|
|
package ethchain
|
|
|
|
|
|
|
|
import (
|
2014-03-30 16:55:51 +00:00
|
|
|
_ "bytes"
|
2014-03-24 12:20:34 +00:00
|
|
|
"fmt"
|
2014-02-24 11:10:45 +00:00
|
|
|
"github.com/ethereum/eth-go/ethdb"
|
|
|
|
"github.com/ethereum/eth-go/ethutil"
|
2014-03-24 12:20:34 +00:00
|
|
|
"github.com/obscuren/mutan"
|
2014-02-24 11:10:45 +00:00
|
|
|
"math/big"
|
2014-03-24 12:20:34 +00:00
|
|
|
"strings"
|
2014-02-24 11:10:45 +00:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
2014-03-30 16:55:51 +00:00
|
|
|
/*
|
2014-03-20 16:26:07 +00:00
|
|
|
func TestRun3(t *testing.T) {
|
|
|
|
ethutil.ReadConfig("")
|
|
|
|
|
|
|
|
db, _ := ethdb.NewMemDatabase()
|
|
|
|
state := NewState(ethutil.NewTrie(db, ""))
|
|
|
|
|
|
|
|
script := Compile([]string{
|
|
|
|
"PUSH", "300",
|
2014-03-20 18:50:53 +00:00
|
|
|
"PUSH", "0",
|
2014-03-20 16:26:07 +00:00
|
|
|
"MSTORE",
|
2014-03-21 10:54:36 +00:00
|
|
|
|
|
|
|
"PUSH", "32",
|
|
|
|
"CALLDATA",
|
|
|
|
|
|
|
|
"PUSH", "64",
|
2014-03-20 16:26:07 +00:00
|
|
|
"PUSH", "0",
|
|
|
|
"RETURN",
|
|
|
|
})
|
2014-03-27 22:17:23 +00:00
|
|
|
tx := NewContractCreationTx(ethutil.Big("0"), ethutil.Big("1000"), script)
|
2014-03-20 16:26:07 +00:00
|
|
|
addr := tx.Hash()[12:]
|
|
|
|
contract := MakeContract(tx, state)
|
2014-03-20 22:38:16 +00:00
|
|
|
state.UpdateContract(contract)
|
2014-03-20 16:26:07 +00:00
|
|
|
|
2014-03-24 12:20:34 +00:00
|
|
|
callerScript := ethutil.Assemble(
|
2014-03-21 14:27:18 +00:00
|
|
|
"PUSH", 1337, // Argument
|
|
|
|
"PUSH", 65, // argument mem offset
|
2014-03-21 10:54:36 +00:00
|
|
|
"MSTORE",
|
2014-03-21 14:27:18 +00:00
|
|
|
"PUSH", 64, // ret size
|
|
|
|
"PUSH", 0, // ret offset
|
|
|
|
|
|
|
|
"PUSH", 32, // arg size
|
|
|
|
"PUSH", 65, // arg offset
|
|
|
|
"PUSH", 1000, /// Gas
|
|
|
|
"PUSH", 0, /// value
|
|
|
|
"PUSH", addr, // Sender
|
2014-03-20 16:26:07 +00:00
|
|
|
"CALL",
|
2014-03-21 14:27:18 +00:00
|
|
|
"PUSH", 64,
|
|
|
|
"PUSH", 0,
|
2014-03-21 10:54:36 +00:00
|
|
|
"RETURN",
|
2014-03-21 14:27:18 +00:00
|
|
|
)
|
2014-03-27 22:17:23 +00:00
|
|
|
callerTx := NewContractCreationTx(ethutil.Big("0"), ethutil.Big("1000"), callerScript)
|
2014-03-20 16:26:07 +00:00
|
|
|
|
2014-03-20 22:38:16 +00:00
|
|
|
// Contract addr as test address
|
2014-03-20 22:17:53 +00:00
|
|
|
account := NewAccount(ContractAddr, big.NewInt(10000000))
|
|
|
|
callerClosure := NewClosure(account, MakeContract(callerTx, state), state, big.NewInt(1000000000), new(big.Int))
|
2014-03-20 16:26:07 +00:00
|
|
|
|
2014-03-20 18:50:53 +00:00
|
|
|
vm := NewVm(state, RuntimeVars{
|
2014-03-21 13:47:55 +00:00
|
|
|
origin: account.Address(),
|
2014-03-20 16:26:07 +00:00
|
|
|
blockNumber: 1,
|
|
|
|
prevHash: ethutil.FromHex("5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6"),
|
|
|
|
coinbase: ethutil.FromHex("2adc25665018aa1fe0e6bc666dac8fc2697ff9ba"),
|
|
|
|
time: 1,
|
|
|
|
diff: big.NewInt(256),
|
2014-03-20 22:38:16 +00:00
|
|
|
// XXX Tx data? Could be just an argument to the closure instead
|
|
|
|
txData: nil,
|
2014-03-20 16:26:07 +00:00
|
|
|
})
|
2014-03-21 10:54:36 +00:00
|
|
|
ret := callerClosure.Call(vm, nil)
|
|
|
|
|
|
|
|
exp := []byte{0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 44, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 57}
|
|
|
|
if bytes.Compare(ret, exp) != 0 {
|
|
|
|
t.Errorf("expected return value to be %v, got %v", exp, ret)
|
|
|
|
}
|
2014-03-30 16:55:51 +00:00
|
|
|
}*/
|
2014-03-24 12:20:34 +00:00
|
|
|
|
|
|
|
func TestRun4(t *testing.T) {
|
|
|
|
ethutil.ReadConfig("")
|
|
|
|
|
|
|
|
db, _ := ethdb.NewMemDatabase()
|
|
|
|
state := NewState(ethutil.NewTrie(db, ""))
|
|
|
|
|
2014-03-30 10:58:37 +00:00
|
|
|
asm, err := mutan.Compile(strings.NewReader(`
|
2014-04-10 18:40:12 +00:00
|
|
|
int32 a = 10
|
|
|
|
int32 b = 20
|
|
|
|
if a > b {
|
|
|
|
int32 c = this.caller()
|
|
|
|
}
|
|
|
|
exit()
|
|
|
|
`), false)
|
|
|
|
script := ethutil.Assemble(asm...)
|
|
|
|
tx := NewContractCreationTx(ethutil.Big("0"), ethutil.Big("1000"), script)
|
|
|
|
addr := tx.Hash()[12:]
|
|
|
|
contract := MakeContract(tx, state)
|
|
|
|
state.UpdateContract(contract)
|
|
|
|
fmt.Printf("%x\n", addr)
|
|
|
|
|
|
|
|
asm, err = mutan.Compile(strings.NewReader(`
|
2014-04-05 08:49:07 +00:00
|
|
|
int32 a = 10
|
|
|
|
int32 b = 10
|
2014-03-30 16:55:51 +00:00
|
|
|
if a == b {
|
2014-04-05 08:49:07 +00:00
|
|
|
int32 c = 10
|
2014-03-30 20:03:08 +00:00
|
|
|
if c == 10 {
|
2014-04-05 08:49:07 +00:00
|
|
|
int32 d = 1000
|
|
|
|
int32 e = 10
|
2014-03-30 20:03:08 +00:00
|
|
|
}
|
2014-03-30 16:55:51 +00:00
|
|
|
}
|
2014-03-30 20:03:08 +00:00
|
|
|
|
|
|
|
store[0] = 20
|
|
|
|
store[a] = 20
|
2014-04-05 08:49:07 +00:00
|
|
|
store[b] = this.caller()
|
|
|
|
|
2014-04-10 18:40:12 +00:00
|
|
|
int8 ret = 0
|
|
|
|
int8 arg = 10
|
2014-04-10 22:14:19 +00:00
|
|
|
addr address = "a46df28529eb8aa8b8c025b0b413c5f4b688352f"
|
|
|
|
call(address, 0, 100000000, arg, ret)
|
2014-03-30 10:58:37 +00:00
|
|
|
`), false)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Println(err)
|
|
|
|
}
|
2014-04-10 22:14:19 +00:00
|
|
|
//asm = append(asm, "LOG")
|
2014-03-24 12:20:34 +00:00
|
|
|
fmt.Println(asm)
|
|
|
|
|
|
|
|
callerScript := ethutil.Assemble(asm...)
|
2014-03-27 22:17:23 +00:00
|
|
|
callerTx := NewContractCreationTx(ethutil.Big("0"), ethutil.Big("1000"), callerScript)
|
2014-03-24 12:20:34 +00:00
|
|
|
|
|
|
|
// Contract addr as test address
|
|
|
|
account := NewAccount(ContractAddr, big.NewInt(10000000))
|
2014-04-09 16:27:54 +00:00
|
|
|
c := MakeContract(callerTx, state)
|
|
|
|
callerClosure := NewClosure(account, c, c.script, state, big.NewInt(1000000000), new(big.Int))
|
2014-03-24 12:20:34 +00:00
|
|
|
|
|
|
|
vm := NewVm(state, RuntimeVars{
|
|
|
|
origin: account.Address(),
|
|
|
|
blockNumber: 1,
|
|
|
|
prevHash: ethutil.FromHex("5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6"),
|
|
|
|
coinbase: ethutil.FromHex("2adc25665018aa1fe0e6bc666dac8fc2697ff9ba"),
|
|
|
|
time: 1,
|
|
|
|
diff: big.NewInt(256),
|
|
|
|
// XXX Tx data? Could be just an argument to the closure instead
|
|
|
|
txData: nil,
|
|
|
|
})
|
|
|
|
callerClosure.Call(vm, nil)
|
|
|
|
}
|