mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-03 17:44:29 +00:00
447f20d395
* Baikal testnet configuration * Fixes * Change AsMessage signature * Fixes in t8ntool * More updates * Fix misspelling * Skip eip1559 transition test * More bootnodes Co-authored-by: Alex Sharp <alexsharp@Alexs-MacBook-Pro.local>
116 lines
3.7 KiB
Go
116 lines
3.7 KiB
Go
package misc
|
|
|
|
import (
|
|
"math/big"
|
|
"testing"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/common"
|
|
"github.com/ledgerwatch/turbo-geth/core/types"
|
|
"github.com/ledgerwatch/turbo-geth/params"
|
|
)
|
|
|
|
// copyConfig does a _shallow_ copy of a given config. Safe to set new values, but
|
|
// do not use e.g. SetInt() on the numbers. For testing only
|
|
func copyConfig(original *params.ChainConfig) *params.ChainConfig {
|
|
return ¶ms.ChainConfig{
|
|
ChainID: original.ChainID,
|
|
HomesteadBlock: original.HomesteadBlock,
|
|
DAOForkBlock: original.DAOForkBlock,
|
|
DAOForkSupport: original.DAOForkSupport,
|
|
EIP150Block: original.EIP150Block,
|
|
EIP150Hash: original.EIP150Hash,
|
|
EIP155Block: original.EIP155Block,
|
|
EIP158Block: original.EIP158Block,
|
|
ByzantiumBlock: original.ByzantiumBlock,
|
|
ConstantinopleBlock: original.ConstantinopleBlock,
|
|
PetersburgBlock: original.PetersburgBlock,
|
|
IstanbulBlock: original.IstanbulBlock,
|
|
MuirGlacierBlock: original.MuirGlacierBlock,
|
|
BerlinBlock: original.BerlinBlock,
|
|
LondonBlock: original.LondonBlock,
|
|
Ethash: original.Ethash,
|
|
Clique: original.Clique,
|
|
}
|
|
}
|
|
|
|
func config() *params.ChainConfig {
|
|
config := copyConfig(params.TestChainConfig)
|
|
config.LondonBlock = big.NewInt(5)
|
|
return config
|
|
}
|
|
|
|
// TestBlockGasLimits tests the gasLimit checks for blocks both across
|
|
// the EIP-1559 boundary and post-1559 blocks
|
|
func TestBlockGasLimits(t *testing.T) {
|
|
initial := new(big.Int).SetUint64(params.InitialBaseFee)
|
|
|
|
for i, tc := range []struct {
|
|
pGasLimit uint64
|
|
pNum int64
|
|
gasLimit uint64
|
|
ok bool
|
|
}{
|
|
// Transitions from non-london to london
|
|
{10000000, 4, 20000000, true}, // No change
|
|
{10000000, 4, 20019531, true}, // Upper limit
|
|
{10000000, 4, 20019532, false}, // Upper +1
|
|
{10000000, 4, 19980470, true}, // Lower limit
|
|
{10000000, 4, 19980469, false}, // Lower limit -1
|
|
// London to London
|
|
{20000000, 5, 20000000, true},
|
|
{20000000, 5, 20019531, true}, // Upper limit
|
|
{20000000, 5, 20019532, false}, // Upper limit +1
|
|
{20000000, 5, 19980470, true}, // Lower limit
|
|
{20000000, 5, 19980469, false}, // Lower limit -1
|
|
{40000000, 5, 40039063, true}, // Upper limit
|
|
{40000000, 5, 40039064, false}, // Upper limit +1
|
|
{40000000, 5, 39960938, true}, // lower limit
|
|
{40000000, 5, 39960937, false}, // Lower limit -1
|
|
} {
|
|
parent := &types.Header{
|
|
GasUsed: tc.pGasLimit / 2,
|
|
GasLimit: tc.pGasLimit,
|
|
BaseFee: initial,
|
|
Number: big.NewInt(tc.pNum),
|
|
}
|
|
header := &types.Header{
|
|
GasUsed: tc.gasLimit / 2,
|
|
GasLimit: tc.gasLimit,
|
|
BaseFee: initial,
|
|
Number: big.NewInt(tc.pNum + 1),
|
|
}
|
|
err := VerifyEip1559Header(config(), parent, header)
|
|
if tc.ok && err != nil {
|
|
t.Errorf("test %d: Expected valid header: %s", i, err)
|
|
}
|
|
if !tc.ok && err == nil {
|
|
t.Errorf("test %d: Expected invalid header", i)
|
|
}
|
|
}
|
|
}
|
|
|
|
// TestCalcBaseFee assumes all blocks are 1559-blocks
|
|
func TestCalcBaseFee(t *testing.T) {
|
|
tests := []struct {
|
|
parentBaseFee int64
|
|
parentGasLimit uint64
|
|
parentGasUsed uint64
|
|
expectedBaseFee int64
|
|
}{
|
|
{params.InitialBaseFee, 20000000, 10000000, params.InitialBaseFee}, // usage == target
|
|
{params.InitialBaseFee, 20000000, 9000000, 987500000}, // usage below target
|
|
{params.InitialBaseFee, 20000000, 11000000, 1012500000}, // usage above target
|
|
}
|
|
for i, test := range tests {
|
|
parent := &types.Header{
|
|
Number: common.Big32,
|
|
GasLimit: test.parentGasLimit,
|
|
GasUsed: test.parentGasUsed,
|
|
BaseFee: big.NewInt(test.parentBaseFee),
|
|
}
|
|
if have, want := CalcBaseFee(config(), parent), big.NewInt(test.expectedBaseFee); have.Cmp(want) != 0 {
|
|
t.Errorf("test %d: have %d want %d, ", i, have, want)
|
|
}
|
|
}
|
|
}
|