620f6a6770
* add gasWanted transient store keys * add gasWanted transient store keeper functions * add gasWanted transient store tracker * add comment * remove unncesary comment * remove unnecesary function * fix tests * fix bad comment * remove unnecesary comment * update comment * update changelog * Update CHANGELOG.md Co-authored-by: Federico Kunze Küllmer <31522760+fedekunze@users.noreply.github.com> * add GasWantedDecorator * remove unnecesary comments * gasWanted decorator test * fix tests * fix tests and build * fix lint * updated end block event * Update app/ante/fee_market.go Co-authored-by: Federico Kunze Küllmer <31522760+fedekunze@users.noreply.github.com> * fix undeclared variable * Update app/ante/fee_market_test.go * remove unnecesary line * migrate MinGasMultiplier to FeeMarket module * set limited gas wanted * remove old newKeeper param * update proto comment * fix test * update comments * Update x/feemarket/keeper/abci.go Co-authored-by: Federico Kunze Küllmer <31522760+fedekunze@users.noreply.github.com> * address comments from review * tidy * tests Co-authored-by: Federico Kunze Küllmer <31522760+fedekunze@users.noreply.github.com>
116 lines
2.9 KiB
Go
116 lines
2.9 KiB
Go
package keeper_test
|
|
|
|
import (
|
|
"fmt"
|
|
abci "github.com/tendermint/tendermint/abci/types"
|
|
"math/big"
|
|
)
|
|
|
|
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)
|
|
},
|
|
suite.app.FeeMarketKeeper.GetParams(suite.ctx).BaseFee.BigInt(),
|
|
},
|
|
{
|
|
"with BaseFee - parent block wanted the same gas as its target",
|
|
false,
|
|
func() {
|
|
// non initial block
|
|
suite.ctx = suite.ctx.WithBlockHeight(1)
|
|
|
|
// Set gas used
|
|
suite.app.FeeMarketKeeper.SetBlockGasWanted(suite.ctx, 100)
|
|
|
|
// 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)
|
|
},
|
|
suite.app.FeeMarketKeeper.GetParams(suite.ctx).BaseFee.BigInt(),
|
|
},
|
|
{
|
|
"with BaseFee - parent block wanted more gas than its target",
|
|
false,
|
|
func() {
|
|
suite.ctx = suite.ctx.WithBlockHeight(1)
|
|
|
|
suite.app.FeeMarketKeeper.SetBlockGasWanted(suite.ctx, 200)
|
|
|
|
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),
|
|
},
|
|
{
|
|
"with BaseFee - Parent gas wanted smaller than parent gas target",
|
|
false,
|
|
func() {
|
|
suite.ctx = suite.ctx.WithBlockHeight(1)
|
|
|
|
suite.app.FeeMarketKeeper.SetBlockGasWanted(suite.ctx, 50)
|
|
|
|
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)
|
|
}
|
|
})
|
|
}
|
|
}
|