ethclient/gethclient: testcase for createAccessList, make tabledriven (#30194)

Adds testcase for createAccessList when user requested gasPrice is less than baseFee, also makes the tests tabledriven
---------

Co-authored-by: Martin Holst Swende <martin@swende.se>
release/1.14
SangIlMo 2 weeks ago committed by Martin HS
parent 13413be184
commit a01688eb23
  1. 95
      ethclient/gethclient/gethclient_test.go

@ -21,6 +21,7 @@ import (
"context" "context"
"encoding/json" "encoding/json"
"math/big" "math/big"
"strings"
"testing" "testing"
"github.com/ethereum/go-ethereum" "github.com/ethereum/go-ethereum"
@ -164,55 +165,85 @@ func TestGethClient(t *testing.T) {
func testAccessList(t *testing.T, client *rpc.Client) { func testAccessList(t *testing.T, client *rpc.Client) {
ec := New(client) ec := New(client)
// Test transfer
msg := ethereum.CallMsg{ for i, tc := range []struct {
msg ethereum.CallMsg
wantGas uint64
wantErr string
wantVMErr string
wantAL string
}{
{ // Test transfer
msg: ethereum.CallMsg{
From: testAddr, From: testAddr,
To: &common.Address{}, To: &common.Address{},
Gas: 21000, Gas: 21000,
GasPrice: big.NewInt(875000000), GasPrice: big.NewInt(875000000),
Value: big.NewInt(1), Value: big.NewInt(1),
} },
al, gas, vmErr, err := ec.CreateAccessList(context.Background(), msg) wantGas: 21000,
if err != nil { wantAL: `[]`,
t.Fatalf("unexpected error: %v", err) },
} { // Test reverting transaction
if vmErr != "" { msg: ethereum.CallMsg{
t.Fatalf("unexpected vm error: %v", vmErr)
}
if gas != 21000 {
t.Fatalf("unexpected gas used: %v", gas)
}
if len(*al) != 0 {
t.Fatalf("unexpected length of accesslist: %v", len(*al))
}
// Test reverting transaction
msg = ethereum.CallMsg{
From: testAddr, From: testAddr,
To: nil, To: nil,
Gas: 100000, Gas: 100000,
GasPrice: big.NewInt(1000000000), GasPrice: big.NewInt(1000000000),
Value: big.NewInt(1), Value: big.NewInt(1),
Data: common.FromHex("0x608060806080608155fd"), Data: common.FromHex("0x608060806080608155fd"),
},
wantGas: 77496,
wantVMErr: "execution reverted",
wantAL: `[
{
"address": "0x3a220f351252089d385b29beca14e27f204c296a",
"storageKeys": [
"0x0000000000000000000000000000000000000000000000000000000000000081"
]
} }
al, gas, vmErr, err = ec.CreateAccessList(context.Background(), msg) ]`,
if err != nil { },
t.Fatalf("unexpected error: %v", err) { // error when gasPrice is less than baseFee
msg: ethereum.CallMsg{
From: testAddr,
To: &common.Address{},
Gas: 21000,
GasPrice: big.NewInt(1), // less than baseFee
Value: big.NewInt(1),
},
wantErr: "max fee per gas less than block base fee",
},
{ // when gasPrice is not specified
msg: ethereum.CallMsg{
From: testAddr,
To: &common.Address{},
Gas: 21000,
Value: big.NewInt(1),
},
wantGas: 21000,
wantAL: `[]`,
},
} {
al, gas, vmErr, err := ec.CreateAccessList(context.Background(), tc.msg)
if tc.wantErr != "" {
if !strings.Contains(err.Error(), tc.wantErr) {
t.Fatalf("test %d: wrong error: %v", i, err)
} }
if vmErr == "" { continue
t.Fatalf("wanted vmErr, got none") } else if err != nil {
t.Fatalf("test %d: wrong error: %v", i, err)
} }
if gas == 21000 { if have, want := vmErr, tc.wantVMErr; have != want {
t.Fatalf("unexpected gas used: %v", gas) t.Fatalf("test %d: vmErr wrong, have %v want %v", i, have, want)
} }
if len(*al) != 1 || al.StorageKeys() != 1 { if have, want := gas, tc.wantGas; have != want {
t.Fatalf("unexpected length of accesslist: %v", len(*al)) t.Fatalf("test %d: gas wrong, have %v want %v", i, have, want)
} }
// address changes between calls, so we can't test for it. haveList, _ := json.MarshalIndent(al, "", " ")
if (*al)[0].Address == common.HexToAddress("0x0") { if have, want := string(haveList), tc.wantAL; have != want {
t.Fatalf("unexpected address: %v", (*al)[0].Address) t.Fatalf("test %d: access list wrong, have:\n%v\nwant:\n%v", i, have, want)
} }
if (*al)[0].StorageKeys[0] != common.HexToHash("0x0000000000000000000000000000000000000000000000000000000000000081") {
t.Fatalf("unexpected storage key: %v", (*al)[0].StorageKeys[0])
} }
} }

Loading…
Cancel
Save