diff options
author | Wei-Ning Huang <w@dexon.org> | 2018-11-23 12:12:10 +0800 |
---|---|---|
committer | Wei-Ning Huang <w@dexon.org> | 2019-04-09 21:32:54 +0800 |
commit | e79dcc385d37eefb121f675d3800dbfe59b515c7 (patch) | |
tree | 220cd446864dcca990d1adeafd23fe7e301ced7e /cmd | |
parent | c51c2a240cd3f01bf8bdb6a1644a902b2335b2aa (diff) | |
download | dexon-e79dcc385d37eefb121f675d3800dbfe59b515c7.tar.gz dexon-e79dcc385d37eefb121f675d3800dbfe59b515c7.tar.zst dexon-e79dcc385d37eefb121f675d3800dbfe59b515c7.zip |
api: allow sending batch of raw transactions
Diffstat (limited to 'cmd')
-rw-r--r-- | cmd/monkey/gambler.go | 33 | ||||
-rw-r--r-- | cmd/monkey/key | 1 | ||||
-rw-r--r-- | cmd/monkey/monkey.go | 140 |
3 files changed, 95 insertions, 79 deletions
diff --git a/cmd/monkey/gambler.go b/cmd/monkey/gambler.go index ecddb7d0f..8151f2c22 100644 --- a/cmd/monkey/gambler.go +++ b/cmd/monkey/gambler.go @@ -18,7 +18,6 @@ package main import ( - "crypto/ecdsa" "fmt" "math" "math/big" @@ -55,7 +54,14 @@ func (m *Monkey) Gamble() { if err != nil { panic(err) } - m.call(m.source, contract, input, new(big.Int).Set(oneDEX), 0, math.MaxUint64) + m.transfer(&transferContext{ + Key: m.source, + ToAddress: contract, + Amount: new(big.Int).Set(oneDEX), + Data: input, + Gas: 0, + Nonce: math.MaxUint64, + }) time.Sleep(5 * time.Second) @@ -64,20 +70,27 @@ func (m *Monkey) Gamble() { panic(err) } - call := func(key *ecdsa.PrivateKey, nonce uint64) { - m.call(key, contract, input, big.NewInt(100000), uint64(32740), nonce) - } - nonce := uint64(0) for { fmt.Println("nonce", nonce) - for _, key := range m.keys { - if *parallel { - go call(key, nonce) + ctxs := make([]*transferContext, len(m.keys)) + for i, key := range m.keys { + ctx := &transferContext{ + Key: key, + ToAddress: contract, + Amount: big.NewInt(1), + Data: input, + Nonce: nonce, + } + if *batch { + ctxs[i] = ctx } else { - call(key, nonce) + m.transfer(ctx) } } + if *batch { + m.batchTransfer(ctxs) + } nonce += 1 time.Sleep(time.Duration(*sleep) * time.Millisecond) } diff --git a/cmd/monkey/key b/cmd/monkey/key deleted file mode 100644 index a9fe18413..000000000 --- a/cmd/monkey/key +++ /dev/null @@ -1 +0,0 @@ -fa30b47a7a3d5ab6935d873ffaeb8ca5b9782d102c4094be6da6b7f2fc04b5bd
\ No newline at end of file diff --git a/cmd/monkey/monkey.go b/cmd/monkey/monkey.go index 6ac9be5f3..f55d195a6 100644 --- a/cmd/monkey/monkey.go +++ b/cmd/monkey/monkey.go @@ -40,7 +40,7 @@ var key = flag.String("key", "", "private key path") var endpoint = flag.String("endpoint", "http://127.0.0.1:8545", "JSON RPC endpoint") var n = flag.Int("n", 100, "number of random accounts") var gambler = flag.Bool("gambler", false, "make this monkey a gambler") -var parallel = flag.Bool("parallel", false, "monkeys will send transaction in parallel") +var batch = flag.Bool("batch", false, "monkeys will send transaction in batch") var sleep = flag.Int("sleep", 500, "time in millisecond that monkeys sleep between each transaction") type Monkey struct { @@ -79,35 +79,70 @@ func New(ep string, source *ecdsa.PrivateKey, num int) *Monkey { } } -func (m *Monkey) transfer( - key *ecdsa.PrivateKey, toAddress common.Address, amount *big.Int, nonce uint64) { +type transferContext struct { + Key *ecdsa.PrivateKey + ToAddress common.Address + Amount *big.Int + Data []byte + Nonce uint64 + Gas uint64 +} - if nonce == math.MaxUint64 { +func (m *Monkey) prepareTx(ctx *transferContext) *types.Transaction { + if ctx.Nonce == math.MaxUint64 { var err error - address := crypto.PubkeyToAddress(key.PublicKey) - nonce, err = m.client.PendingNonceAt(context.Background(), address) + address := crypto.PubkeyToAddress(ctx.Key.PublicKey) + ctx.Nonce, err = m.client.PendingNonceAt(context.Background(), address) + if err != nil { + panic(err) + } + } + + if ctx.Gas == uint64(0) { + var err error + ctx.Gas, err = m.client.EstimateGas(context.Background(), dexon.CallMsg{ + Data: ctx.Data, + }) if err != nil { panic(err) } } tx := types.NewTransaction( - uint64(nonce), - toAddress, - amount, + ctx.Nonce, + ctx.ToAddress, + ctx.Amount, uint64(21000), big.NewInt(1e9), nil) signer := types.NewEIP155Signer(m.networkID) - tx, err := types.SignTx(tx, signer, key) + tx, err := types.SignTx(tx, signer, ctx.Key) if err != nil { panic(err) } + return tx +} + +func (m *Monkey) transfer(ctx *transferContext) { + tx := m.prepareTx(ctx) + fmt.Println("Sending TX", "fullhash", tx.Hash().String()) + err := m.client.SendTransaction(context.Background(), tx) + if err != nil { + panic(err) + } +} - err = m.client.SendTransaction(context.Background(), tx) +func (m *Monkey) batchTransfer(ctxs []*transferContext) { + txs := make([]*types.Transaction, len(ctxs)) + for i, ctx := range ctxs { + txs[i] = m.prepareTx(ctx) + fmt.Println("Sending TX", "fullhash", txs[i].Hash().String()) + } + + err := m.client.SendTransactions(context.Background(), txs) if err != nil { panic(err) } @@ -139,7 +174,7 @@ func (m *Monkey) deploy( } tx := types.NewContractCreation( - uint64(nonce), + nonce, amount, gas, big.NewInt(1e9), @@ -171,53 +206,6 @@ func (m *Monkey) deploy( } } -func (m *Monkey) call( - key *ecdsa.PrivateKey, contract common.Address, input []byte, amount *big.Int, gas uint64, nonce uint64) { - - address := crypto.PubkeyToAddress(key.PublicKey) - if nonce == math.MaxUint64 { - var err error - nonce, err = m.client.PendingNonceAt(context.Background(), address) - if err != nil { - panic(err) - } - } - - if gas == uint64(0) { - var err error - gas, err = m.client.EstimateGas(context.Background(), dexon.CallMsg{ - From: address, - To: &contract, - Value: amount, - Data: input, - }) - if err != nil { - panic(err) - } - } - - tx := types.NewTransaction( - uint64(nonce), - contract, - amount, - gas, - big.NewInt(1e9), - input) - - signer := types.NewEIP155Signer(m.networkID) - tx, err := types.SignTx(tx, signer, key) - if err != nil { - panic(err) - } - - fmt.Println("Sending TX", "fullhash", tx.Hash().String()) - - err = m.client.SendTransaction(context.Background(), tx) - if err != nil { - panic(err) - } -} - func (m *Monkey) Distribute() { fmt.Println("Distributing DEX to random accounts ...") address := crypto.PubkeyToAddress(m.source.PublicKey) @@ -226,32 +214,48 @@ func (m *Monkey) Distribute() { panic(err) } - for _, key := range m.keys { + ctxs := make([]*transferContext, len(m.keys)) + for i, key := range m.keys { address := crypto.PubkeyToAddress(key.PublicKey) amount := new(big.Int) amount.SetString("1000000000000000000", 10) - m.transfer(m.source, address, amount, nonce) + ctxs[i] = &transferContext{ + Key: m.source, + ToAddress: address, + Amount: amount, + Nonce: nonce, + Gas: 21000, + } nonce += 1 } + m.batchTransfer(ctxs) time.Sleep(20 * time.Second) } func (m *Monkey) Crazy() { fmt.Println("Performing random transfers ...") nonce := uint64(0) - transfer := func(key *ecdsa.PrivateKey, to common.Address, nonce uint64) { - m.transfer(key, to, big.NewInt(1), nonce) - } for { fmt.Println("nonce", nonce) - for _, key := range m.keys { + ctxs := make([]*transferContext, len(m.keys)) + for i, key := range m.keys { to := crypto.PubkeyToAddress(m.keys[rand.Int()%len(m.keys)].PublicKey) - if *parallel { - go transfer(key, to, nonce) + ctx := &transferContext{ + Key: key, + ToAddress: to, + Amount: big.NewInt(1), + Nonce: nonce, + Gas: 21000, + } + if *batch { + ctxs[i] = ctx } else { - transfer(key, to, nonce) + m.transfer(ctx) } } + if *batch { + m.batchTransfer(ctxs) + } nonce += 1 time.Sleep(time.Duration(*sleep) * time.Millisecond) } |