mirror of
https://github.com/ethereum/go-ethereum.git
synced 2026-05-13 03:26:38 +00:00
accounts/abi/abigen: fix a flaky bind test case NewSingleStructArgument (#31501)
found the failed testcase here https://ci.appveyor.com/project/ethereum/go-ethereum/builds/51767091/job/rbjke432c05pufja add a timeout to wait the tx to be mined. --------- Signed-off-by: jsvisa <delweng@gmail.com> Co-authored-by: Jared Wasinger <j-wasinger@hotmail.com>
This commit is contained in:
parent
7e3170fb5c
commit
d342f76232
1 changed files with 34 additions and 21 deletions
|
|
@ -541,7 +541,7 @@ var bindTests = []struct {
|
||||||
struct A {
|
struct A {
|
||||||
bytes32 B;
|
bytes32 B;
|
||||||
}
|
}
|
||||||
|
|
||||||
function F() public view returns (A[] memory a, uint256[] memory c, bool[] memory d) {
|
function F() public view returns (A[] memory a, uint256[] memory c, bool[] memory d) {
|
||||||
A[] memory a = new A[](2);
|
A[] memory a = new A[](2);
|
||||||
a[0].B = bytes32(uint256(1234) << 96);
|
a[0].B = bytes32(uint256(1234) << 96);
|
||||||
|
|
@ -549,7 +549,7 @@ var bindTests = []struct {
|
||||||
bool[] memory d;
|
bool[] memory d;
|
||||||
return (a, c, d);
|
return (a, c, d);
|
||||||
}
|
}
|
||||||
|
|
||||||
function G() public view returns (A[] memory a) {
|
function G() public view returns (A[] memory a) {
|
||||||
A[] memory a = new A[](2);
|
A[] memory a = new A[](2);
|
||||||
a[0].B = bytes32(uint256(1234) << 96);
|
a[0].B = bytes32(uint256(1234) << 96);
|
||||||
|
|
@ -571,10 +571,10 @@ var bindTests = []struct {
|
||||||
// Generate a new random account and a funded simulator
|
// Generate a new random account and a funded simulator
|
||||||
key, _ := crypto.GenerateKey()
|
key, _ := crypto.GenerateKey()
|
||||||
auth, _ := bind.NewKeyedTransactorWithChainID(key, big.NewInt(1337))
|
auth, _ := bind.NewKeyedTransactorWithChainID(key, big.NewInt(1337))
|
||||||
|
|
||||||
sim := backends.NewSimulatedBackend(types.GenesisAlloc{auth.From: {Balance: big.NewInt(10000000000000000)}}, 10000000)
|
sim := backends.NewSimulatedBackend(types.GenesisAlloc{auth.From: {Balance: big.NewInt(10000000000000000)}}, 10000000)
|
||||||
defer sim.Close()
|
defer sim.Close()
|
||||||
|
|
||||||
// Deploy a structs method invoker contract and execute its default method
|
// Deploy a structs method invoker contract and execute its default method
|
||||||
_, _, structs, err := DeployStructs(auth, sim)
|
_, _, structs, err := DeployStructs(auth, sim)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
@ -1701,13 +1701,13 @@ var bindTests = []struct {
|
||||||
`NewFallbacks`,
|
`NewFallbacks`,
|
||||||
`
|
`
|
||||||
pragma solidity >=0.6.0 <0.7.0;
|
pragma solidity >=0.6.0 <0.7.0;
|
||||||
|
|
||||||
contract NewFallbacks {
|
contract NewFallbacks {
|
||||||
event Fallback(bytes data);
|
event Fallback(bytes data);
|
||||||
fallback() external {
|
fallback() external {
|
||||||
emit Fallback(msg.data);
|
emit Fallback(msg.data);
|
||||||
}
|
}
|
||||||
|
|
||||||
event Received(address addr, uint value);
|
event Received(address addr, uint value);
|
||||||
receive() external payable {
|
receive() external payable {
|
||||||
emit Received(msg.sender, msg.value);
|
emit Received(msg.sender, msg.value);
|
||||||
|
|
@ -1719,7 +1719,7 @@ var bindTests = []struct {
|
||||||
`
|
`
|
||||||
"bytes"
|
"bytes"
|
||||||
"math/big"
|
"math/big"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
||||||
"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
|
"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
|
||||||
"github.com/ethereum/go-ethereum/core/types"
|
"github.com/ethereum/go-ethereum/core/types"
|
||||||
|
|
@ -1728,22 +1728,22 @@ var bindTests = []struct {
|
||||||
`
|
`
|
||||||
key, _ := crypto.GenerateKey()
|
key, _ := crypto.GenerateKey()
|
||||||
addr := crypto.PubkeyToAddress(key.PublicKey)
|
addr := crypto.PubkeyToAddress(key.PublicKey)
|
||||||
|
|
||||||
sim := backends.NewSimulatedBackend(types.GenesisAlloc{addr: {Balance: big.NewInt(10000000000000000)}}, 1000000)
|
sim := backends.NewSimulatedBackend(types.GenesisAlloc{addr: {Balance: big.NewInt(10000000000000000)}}, 1000000)
|
||||||
defer sim.Close()
|
defer sim.Close()
|
||||||
|
|
||||||
opts, _ := bind.NewKeyedTransactorWithChainID(key, big.NewInt(1337))
|
opts, _ := bind.NewKeyedTransactorWithChainID(key, big.NewInt(1337))
|
||||||
_, _, c, err := DeployNewFallbacks(opts, sim)
|
_, _, c, err := DeployNewFallbacks(opts, sim)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Failed to deploy contract: %v", err)
|
t.Fatalf("Failed to deploy contract: %v", err)
|
||||||
}
|
}
|
||||||
sim.Commit()
|
sim.Commit()
|
||||||
|
|
||||||
// Test receive function
|
// Test receive function
|
||||||
opts.Value = big.NewInt(100)
|
opts.Value = big.NewInt(100)
|
||||||
c.Receive(opts)
|
c.Receive(opts)
|
||||||
sim.Commit()
|
sim.Commit()
|
||||||
|
|
||||||
var gotEvent bool
|
var gotEvent bool
|
||||||
iter, _ := c.FilterReceived(nil)
|
iter, _ := c.FilterReceived(nil)
|
||||||
defer iter.Close()
|
defer iter.Close()
|
||||||
|
|
@ -1760,14 +1760,14 @@ var bindTests = []struct {
|
||||||
if !gotEvent {
|
if !gotEvent {
|
||||||
t.Fatal("Expect to receive event emitted by receive")
|
t.Fatal("Expect to receive event emitted by receive")
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test fallback function
|
// Test fallback function
|
||||||
gotEvent = false
|
gotEvent = false
|
||||||
opts.Value = nil
|
opts.Value = nil
|
||||||
calldata := []byte{0x01, 0x02, 0x03}
|
calldata := []byte{0x01, 0x02, 0x03}
|
||||||
c.Fallback(opts, calldata)
|
c.Fallback(opts, calldata)
|
||||||
sim.Commit()
|
sim.Commit()
|
||||||
|
|
||||||
iter2, _ := c.FilterFallback(nil)
|
iter2, _ := c.FilterFallback(nil)
|
||||||
defer iter2.Close()
|
defer iter2.Close()
|
||||||
for iter2.Next() {
|
for iter2.Next() {
|
||||||
|
|
@ -1806,7 +1806,9 @@ var bindTests = []struct {
|
||||||
[]string{"608060405234801561001057600080fd5b50610113806100206000396000f3fe6080604052348015600f57600080fd5b506004361060285760003560e01c806324ec1d3f14602d575b600080fd5b60336035565b005b7fb4b2ff75e30cb4317eaae16dd8a187dd89978df17565104caa6c2797caae27d460405180604001604052806001815260200160028152506040516078919060ba565b60405180910390a1565b6040820160008201516096600085018260ad565b50602082015160a7602085018260ad565b50505050565b60b48160d3565b82525050565b600060408201905060cd60008301846082565b92915050565b600081905091905056fea26469706673582212208823628796125bf9941ce4eda18da1be3cf2931b231708ab848e1bd7151c0c9a64736f6c63430008070033"},
|
[]string{"608060405234801561001057600080fd5b50610113806100206000396000f3fe6080604052348015600f57600080fd5b506004361060285760003560e01c806324ec1d3f14602d575b600080fd5b60336035565b005b7fb4b2ff75e30cb4317eaae16dd8a187dd89978df17565104caa6c2797caae27d460405180604001604052806001815260200160028152506040516078919060ba565b60405180910390a1565b6040820160008201516096600085018260ad565b50602082015160a7602085018260ad565b50505050565b60b48160d3565b82525050565b600060408201905060cd60008301846082565b92915050565b600081905091905056fea26469706673582212208823628796125bf9941ce4eda18da1be3cf2931b231708ab848e1bd7151c0c9a64736f6c63430008070033"},
|
||||||
[]string{`[{"anonymous":false,"inputs":[{"components":[{"internalType":"uint256","name":"a","type":"uint256"},{"internalType":"uint256","name":"b","type":"uint256"}],"indexed":false,"internalType":"struct Test.MyStruct","name":"s","type":"tuple"}],"name":"StructEvent","type":"event"},{"inputs":[],"name":"TestEvent","outputs":[],"stateMutability":"nonpayable","type":"function"}]`},
|
[]string{`[{"anonymous":false,"inputs":[{"components":[{"internalType":"uint256","name":"a","type":"uint256"},{"internalType":"uint256","name":"b","type":"uint256"}],"indexed":false,"internalType":"struct Test.MyStruct","name":"s","type":"tuple"}],"name":"StructEvent","type":"event"},{"inputs":[],"name":"TestEvent","outputs":[],"stateMutability":"nonpayable","type":"function"}]`},
|
||||||
`
|
`
|
||||||
|
"context"
|
||||||
"math/big"
|
"math/big"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
||||||
"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
|
"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
|
||||||
|
|
@ -1828,12 +1830,23 @@ var bindTests = []struct {
|
||||||
}
|
}
|
||||||
sim.Commit()
|
sim.Commit()
|
||||||
|
|
||||||
_, err = d.TestEvent(user)
|
tx, err := d.TestEvent(user)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Failed to call contract %v", err)
|
t.Fatalf("Failed to call contract %v", err)
|
||||||
}
|
}
|
||||||
sim.Commit()
|
sim.Commit()
|
||||||
|
|
||||||
|
// Wait for the transaction to be mined
|
||||||
|
ctx, cancel := context.WithTimeout(context.Background(), 2*time.Second)
|
||||||
|
defer cancel()
|
||||||
|
receipt, err := bind.WaitMined(ctx, sim, tx)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Failed to wait for tx to be mined: %v", err)
|
||||||
|
}
|
||||||
|
if receipt.Status != types.ReceiptStatusSuccessful {
|
||||||
|
t.Fatal("Transaction failed")
|
||||||
|
}
|
||||||
|
|
||||||
it, err := d.FilterStructEvent(nil)
|
it, err := d.FilterStructEvent(nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Failed to filter contract event %v", err)
|
t.Fatalf("Failed to filter contract event %v", err)
|
||||||
|
|
@ -1862,7 +1875,7 @@ var bindTests = []struct {
|
||||||
`NewErrors`,
|
`NewErrors`,
|
||||||
`
|
`
|
||||||
pragma solidity >0.8.4;
|
pragma solidity >0.8.4;
|
||||||
|
|
||||||
contract NewErrors {
|
contract NewErrors {
|
||||||
error MyError(uint256);
|
error MyError(uint256);
|
||||||
error MyError1(uint256);
|
error MyError1(uint256);
|
||||||
|
|
@ -1878,7 +1891,7 @@ var bindTests = []struct {
|
||||||
`
|
`
|
||||||
"context"
|
"context"
|
||||||
"math/big"
|
"math/big"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
||||||
"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
|
"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
|
||||||
"github.com/ethereum/go-ethereum/core/types"
|
"github.com/ethereum/go-ethereum/core/types"
|
||||||
|
|
@ -1892,7 +1905,7 @@ var bindTests = []struct {
|
||||||
sim = backends.NewSimulatedBackend(types.GenesisAlloc{user.From: {Balance: big.NewInt(1000000000000000000)}}, ethconfig.Defaults.Miner.GasCeil)
|
sim = backends.NewSimulatedBackend(types.GenesisAlloc{user.From: {Balance: big.NewInt(1000000000000000000)}}, ethconfig.Defaults.Miner.GasCeil)
|
||||||
)
|
)
|
||||||
defer sim.Close()
|
defer sim.Close()
|
||||||
|
|
||||||
_, tx, contract, err := DeployNewErrors(user, sim)
|
_, tx, contract, err := DeployNewErrors(user, sim)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
|
|
@ -1917,12 +1930,12 @@ var bindTests = []struct {
|
||||||
name: `ConstructorWithStructParam`,
|
name: `ConstructorWithStructParam`,
|
||||||
contract: `
|
contract: `
|
||||||
pragma solidity >=0.8.0 <0.9.0;
|
pragma solidity >=0.8.0 <0.9.0;
|
||||||
|
|
||||||
contract ConstructorWithStructParam {
|
contract ConstructorWithStructParam {
|
||||||
struct StructType {
|
struct StructType {
|
||||||
uint256 field;
|
uint256 field;
|
||||||
}
|
}
|
||||||
|
|
||||||
constructor(StructType memory st) {}
|
constructor(StructType memory st) {}
|
||||||
}
|
}
|
||||||
`,
|
`,
|
||||||
|
|
@ -1951,7 +1964,7 @@ var bindTests = []struct {
|
||||||
t.Fatalf("DeployConstructorWithStructParam() got err %v; want nil err", err)
|
t.Fatalf("DeployConstructorWithStructParam() got err %v; want nil err", err)
|
||||||
}
|
}
|
||||||
sim.Commit()
|
sim.Commit()
|
||||||
|
|
||||||
if _, err = bind.WaitDeployed(context.Background(), sim, tx); err != nil {
|
if _, err = bind.WaitDeployed(context.Background(), sim, tx); err != nil {
|
||||||
t.Logf("Deployment tx: %+v", tx)
|
t.Logf("Deployment tx: %+v", tx)
|
||||||
t.Errorf("bind.WaitDeployed(nil, %T, <deployment tx>) got err %v; want nil err", sim, err)
|
t.Errorf("bind.WaitDeployed(nil, %T, <deployment tx>) got err %v; want nil err", sim, err)
|
||||||
|
|
@ -2000,7 +2013,7 @@ var bindTests = []struct {
|
||||||
t.Fatalf("DeployNameConflict() got err %v; want nil err", err)
|
t.Fatalf("DeployNameConflict() got err %v; want nil err", err)
|
||||||
}
|
}
|
||||||
sim.Commit()
|
sim.Commit()
|
||||||
|
|
||||||
if _, err = bind.WaitDeployed(context.Background(), sim, tx); err != nil {
|
if _, err = bind.WaitDeployed(context.Background(), sim, tx); err != nil {
|
||||||
t.Logf("Deployment tx: %+v", tx)
|
t.Logf("Deployment tx: %+v", tx)
|
||||||
t.Errorf("bind.WaitDeployed(nil, %T, <deployment tx>) got err %v; want nil err", sim, err)
|
t.Errorf("bind.WaitDeployed(nil, %T, <deployment tx>) got err %v; want nil err", sim, err)
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue