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