2021-11-19 16:22:25 +00:00
|
|
|
package keeper_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
abci "github.com/tendermint/tendermint/abci/types"
|
2022-02-23 18:48:44 +00:00
|
|
|
"math/big"
|
2021-11-19 16:22:25 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func (suite *KeeperTestSuite) TestCalculateBaseFee() {
|
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
NoBaseFee bool
|
|
|
|
malleate func()
|
|
|
|
expFee *big.Int
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
"without BaseFee",
|
|
|
|
true,
|
|
|
|
func() {},
|
|
|
|
nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"with BaseFee - initial EIP-1559 block",
|
|
|
|
false,
|
|
|
|
func() {
|
|
|
|
suite.ctx = suite.ctx.WithBlockHeight(0)
|
|
|
|
},
|
2022-02-23 18:48:44 +00:00
|
|
|
suite.app.FeeMarketKeeper.GetParams(suite.ctx).BaseFee.BigInt(),
|
2021-11-19 16:22:25 +00:00
|
|
|
},
|
|
|
|
{
|
2022-06-05 09:22:33 +00:00
|
|
|
"with BaseFee - parent block wanted the same gas as its target",
|
2021-11-19 16:22:25 +00:00
|
|
|
false,
|
|
|
|
func() {
|
|
|
|
// non initial block
|
|
|
|
suite.ctx = suite.ctx.WithBlockHeight(1)
|
|
|
|
|
|
|
|
// Set gas used
|
2022-06-05 09:22:33 +00:00
|
|
|
suite.app.FeeMarketKeeper.SetBlockGasWanted(suite.ctx, 100)
|
2021-11-19 16:22:25 +00:00
|
|
|
|
|
|
|
// Set target/gasLimit through Consensus Param MaxGas
|
|
|
|
blockParams := abci.BlockParams{
|
|
|
|
MaxGas: 100,
|
|
|
|
MaxBytes: 10,
|
|
|
|
}
|
|
|
|
consParams := abci.ConsensusParams{Block: &blockParams}
|
|
|
|
suite.ctx = suite.ctx.WithConsensusParams(&consParams)
|
|
|
|
|
|
|
|
// set ElasticityMultiplier
|
|
|
|
params := suite.app.FeeMarketKeeper.GetParams(suite.ctx)
|
|
|
|
params.ElasticityMultiplier = 1
|
|
|
|
suite.app.FeeMarketKeeper.SetParams(suite.ctx, params)
|
|
|
|
},
|
2022-02-23 18:48:44 +00:00
|
|
|
suite.app.FeeMarketKeeper.GetParams(suite.ctx).BaseFee.BigInt(),
|
2021-11-19 16:22:25 +00:00
|
|
|
},
|
|
|
|
{
|
2022-06-05 09:22:33 +00:00
|
|
|
"with BaseFee - parent block wanted more gas than its target",
|
2021-11-19 16:22:25 +00:00
|
|
|
false,
|
|
|
|
func() {
|
|
|
|
suite.ctx = suite.ctx.WithBlockHeight(1)
|
|
|
|
|
2022-06-05 09:22:33 +00:00
|
|
|
suite.app.FeeMarketKeeper.SetBlockGasWanted(suite.ctx, 200)
|
2021-11-19 16:22:25 +00:00
|
|
|
|
|
|
|
blockParams := abci.BlockParams{
|
|
|
|
MaxGas: 100,
|
|
|
|
MaxBytes: 10,
|
|
|
|
}
|
|
|
|
consParams := abci.ConsensusParams{Block: &blockParams}
|
|
|
|
suite.ctx = suite.ctx.WithConsensusParams(&consParams)
|
|
|
|
|
|
|
|
params := suite.app.FeeMarketKeeper.GetParams(suite.ctx)
|
|
|
|
params.ElasticityMultiplier = 1
|
|
|
|
suite.app.FeeMarketKeeper.SetParams(suite.ctx, params)
|
|
|
|
},
|
|
|
|
big.NewInt(1125000000),
|
|
|
|
},
|
|
|
|
{
|
2022-06-05 09:22:33 +00:00
|
|
|
"with BaseFee - Parent gas wanted smaller than parent gas target",
|
2021-11-19 16:22:25 +00:00
|
|
|
false,
|
|
|
|
func() {
|
|
|
|
suite.ctx = suite.ctx.WithBlockHeight(1)
|
|
|
|
|
2022-06-05 09:22:33 +00:00
|
|
|
suite.app.FeeMarketKeeper.SetBlockGasWanted(suite.ctx, 50)
|
2021-11-19 16:22:25 +00:00
|
|
|
|
|
|
|
blockParams := abci.BlockParams{
|
|
|
|
MaxGas: 100,
|
|
|
|
MaxBytes: 10,
|
|
|
|
}
|
|
|
|
consParams := abci.ConsensusParams{Block: &blockParams}
|
|
|
|
suite.ctx = suite.ctx.WithConsensusParams(&consParams)
|
|
|
|
|
|
|
|
params := suite.app.FeeMarketKeeper.GetParams(suite.ctx)
|
|
|
|
params.ElasticityMultiplier = 1
|
|
|
|
suite.app.FeeMarketKeeper.SetParams(suite.ctx, params)
|
|
|
|
},
|
|
|
|
big.NewInt(937500000),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
|
|
suite.Run(fmt.Sprintf("Case %s", tc.name), func() {
|
|
|
|
suite.SetupTest() // reset
|
|
|
|
params := suite.app.FeeMarketKeeper.GetParams(suite.ctx)
|
|
|
|
params.NoBaseFee = tc.NoBaseFee
|
|
|
|
suite.app.FeeMarketKeeper.SetParams(suite.ctx, params)
|
|
|
|
|
|
|
|
tc.malleate()
|
|
|
|
|
|
|
|
fee := suite.app.FeeMarketKeeper.CalculateBaseFee(suite.ctx)
|
|
|
|
if tc.NoBaseFee {
|
|
|
|
suite.Require().Nil(fee, tc.name)
|
|
|
|
} else {
|
|
|
|
suite.Require().Equal(tc.expFee, fee, tc.name)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|