Merge pull request #2107 from nspcc-dev/gas-amount-2.x
core: turn off GAS generation at 8M height
This commit is contained in:
commit
5d86176ec1
5 changed files with 40 additions and 4 deletions
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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"`
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
Loading…
Reference in a new issue