Merge pull request #2107 from nspcc-dev/gas-amount-2.x

core: turn off GAS generation at 8M height
This commit is contained in:
Roman Khimov 2021-08-04 19:02:38 +03:00 committed by GitHub
commit 5d86176ec1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 40 additions and 4 deletions

View file

@ -7,6 +7,7 @@ ProtocolConfiguration:
KeepOnlyLatestState: false KeepOnlyLatestState: false
LowPriorityThreshold: 0.001 LowPriorityThreshold: 0.001
MemPoolSize: 50000 MemPoolSize: 50000
NoBonusHeight: 8000000
StandbyValidators: StandbyValidators:
- 03b209fd4f53a7170ea4444e0cb0a6bb6a53c2bd016926989cf85f9b0fba17a70c - 03b209fd4f53a7170ea4444e0cb0a6bb6a53c2bd016926989cf85f9b0fba17a70c
- 02df48f60e8f3e01c48ff40b9b7f1310d7a8b2a193188befe1c2e3df740e895093 - 02df48f60e8f3e01c48ff40b9b7f1310d7a8b2a193188befe1c2e3df740e895093

View file

@ -7,6 +7,7 @@ ProtocolConfiguration:
KeepOnlyLatestState: false KeepOnlyLatestState: false
LowPriorityThreshold: 0.000 LowPriorityThreshold: 0.000
MemPoolSize: 50000 MemPoolSize: 50000
NoBonusHeight: 8000000
StandbyValidators: StandbyValidators:
- 0327da12b5c40200e9f65569476bbff2218da4f32548ff43b6387ec1416a231ee8 - 0327da12b5c40200e9f65569476bbff2218da4f32548ff43b6387ec1416a231ee8
- 026ce35b29147ad09e4afe4ec4a7319095f08198fa8babbe3c56e970b143528d22 - 026ce35b29147ad09e4afe4ec4a7319095f08198fa8babbe3c56e970b143528d22

View file

@ -44,6 +44,8 @@ type (
// MinimumNetworkFee sets the minimum required network fee for transaction to pass validation. // MinimumNetworkFee sets the minimum required network fee for transaction to pass validation.
MinimumNetworkFee util.Fixed8 `yaml:"MinimumNetworkFee"` MinimumNetworkFee util.Fixed8 `yaml:"MinimumNetworkFee"`
MemPoolSize int `yaml:"MemPoolSize"` MemPoolSize int `yaml:"MemPoolSize"`
// NoBonusHeight is the height where GAS generation stops.
NoBonusHeight uint32 `yaml:"NoBonusHeight"`
// SaveStorageBatch enables storage batch saving before every persist. // SaveStorageBatch enables storage batch saving before every persist.
SaveStorageBatch bool `yaml:"SaveStorageBatch"` SaveStorageBatch bool `yaml:"SaveStorageBatch"`
SecondsPerBlock int `yaml:"SecondsPerBlock"` SecondsPerBlock int `yaml:"SecondsPerBlock"`

View file

@ -103,6 +103,7 @@ type Blockchain struct {
generationAmount []int generationAmount []int
decrementInterval int decrementInterval int
noBonusHeight uint32
// All operations on headerList must be called from an // All operations on headerList must be called from an
// headersOp to be routine safe. // headersOp to be routine safe.
@ -184,6 +185,7 @@ func NewBlockchain(s storage.Store, cfg config.ProtocolConfiguration, log *zap.L
generationAmount: genAmount, generationAmount: genAmount,
decrementInterval: decrementInterval, decrementInterval: decrementInterval,
noBonusHeight: cfg.NoBonusHeight,
} }
if err := bc.init(); err != nil { if err := bc.init(); err != nil {
@ -1488,9 +1490,14 @@ func (bc *Blockchain) CalculateClaimable(value util.Fixed8, startHeight, endHeig
di := uint32(bc.decrementInterval) di := uint32(bc.decrementInterval)
ustart := startHeight / di ustart := startHeight / di
if genSize := uint32(len(bc.generationAmount)); ustart < genSize { genSize := uint32(len(bc.generationAmount))
uend := endHeight / di if ustart < genSize && (bc.noBonusHeight == 0 || startHeight < bc.noBonusHeight) {
iend := endHeight % di endHeightMin := endHeight
if bc.noBonusHeight != 0 && endHeightMin > bc.noBonusHeight {
endHeightMin = bc.noBonusHeight
}
uend := endHeightMin / di
iend := endHeightMin % di
if uend >= genSize { if uend >= genSize {
uend = genSize - 1 uend = genSize - 1
iend = di iend = di

View file

@ -187,6 +187,7 @@ func TestGetClaimable(t *testing.T) {
bc.generationAmount = []int{4, 3, 2, 1} bc.generationAmount = []int{4, 3, 2, 1}
bc.decrementInterval = 2 bc.decrementInterval = 2
_, err := bc.genBlocks(10) _, err := bc.genBlocks(10)
bc.noBonusHeight = 6 // stop right before `1`
require.NoError(t, err) require.NoError(t, err)
t.Run("first generation period", func(t *testing.T) { t.Run("first generation period", func(t *testing.T) {
@ -206,16 +207,40 @@ func TestGetClaimable(t *testing.T) {
t.Run("start from the 2-nd block", func(t *testing.T) { t.Run("start from the 2-nd block", func(t *testing.T) {
amount, sysfee, err := bc.CalculateClaimable(util.Fixed8FromInt64(1), 1, 7) amount, sysfee, err := bc.CalculateClaimable(util.Fixed8FromInt64(1), 1, 7)
require.NoError(t, err) require.NoError(t, err)
require.EqualValues(t, 4+3+3+2+2+1, amount) require.EqualValues(t, 4+3+3+2+2, amount)
require.EqualValues(t, 0, sysfee) require.EqualValues(t, 0, sysfee)
}) })
t.Run("end height after generation has ended", func(t *testing.T) { t.Run("end height after generation has ended", func(t *testing.T) {
amount, sysfee, err := bc.CalculateClaimable(util.Fixed8FromInt64(1), 1, 10)
require.NoError(t, err)
require.EqualValues(t, 4+3+3+2+2, amount)
require.EqualValues(t, 0, sysfee)
})
t.Run("end height after generation has ended, noBonusHeight is very big", func(t *testing.T) {
bc.noBonusHeight = 20
amount, sysfee, err := bc.CalculateClaimable(util.Fixed8FromInt64(1), 1, 10) amount, sysfee, err := bc.CalculateClaimable(util.Fixed8FromInt64(1), 1, 10)
require.NoError(t, err) require.NoError(t, err)
require.EqualValues(t, 4+3+3+2+2+1+1, amount) require.EqualValues(t, 4+3+3+2+2+1+1, amount)
require.EqualValues(t, 0, sysfee) require.EqualValues(t, 0, sysfee)
}) })
t.Run("end height after generation has ended, noBonusHeight is 0", func(t *testing.T) {
bc.noBonusHeight = 0
amount, sysfee, err := bc.CalculateClaimable(util.Fixed8FromInt64(1), 1, 10)
require.NoError(t, err)
require.EqualValues(t, 4+3+3+2+2+1+1, amount)
require.EqualValues(t, 0, sysfee)
})
t.Run("noBonusHeight is not divisible by decrement interval", func(t *testing.T) {
bc.noBonusHeight = 5
amount, sysfee, err := bc.CalculateClaimable(util.Fixed8FromInt64(1), 1, 10)
require.NoError(t, err)
require.EqualValues(t, 4+3+3+2, amount)
require.EqualValues(t, 0, sysfee)
})
} }
func TestClose(t *testing.T) { func TestClose(t *testing.T) {