forked from TrueCloudLab/neoneo-go
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
|
||||
LowPriorityThreshold: 0.001
|
||||
MemPoolSize: 50000
|
||||
NoBonusHeight: 8000000
|
||||
StandbyValidators:
|
||||
- 03b209fd4f53a7170ea4444e0cb0a6bb6a53c2bd016926989cf85f9b0fba17a70c
|
||||
- 02df48f60e8f3e01c48ff40b9b7f1310d7a8b2a193188befe1c2e3df740e895093
|
||||
|
|
|
@ -7,6 +7,7 @@ ProtocolConfiguration:
|
|||
KeepOnlyLatestState: false
|
||||
LowPriorityThreshold: 0.000
|
||||
MemPoolSize: 50000
|
||||
NoBonusHeight: 8000000
|
||||
StandbyValidators:
|
||||
- 0327da12b5c40200e9f65569476bbff2218da4f32548ff43b6387ec1416a231ee8
|
||||
- 026ce35b29147ad09e4afe4ec4a7319095f08198fa8babbe3c56e970b143528d22
|
||||
|
|
|
@ -44,6 +44,8 @@ type (
|
|||
// MinimumNetworkFee sets the minimum required network fee for transaction to pass validation.
|
||||
MinimumNetworkFee util.Fixed8 `yaml:"MinimumNetworkFee"`
|
||||
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 bool `yaml:"SaveStorageBatch"`
|
||||
SecondsPerBlock int `yaml:"SecondsPerBlock"`
|
||||
|
|
|
@ -103,6 +103,7 @@ type Blockchain struct {
|
|||
|
||||
generationAmount []int
|
||||
decrementInterval int
|
||||
noBonusHeight uint32
|
||||
|
||||
// All operations on headerList must be called from an
|
||||
// headersOp to be routine safe.
|
||||
|
@ -184,6 +185,7 @@ func NewBlockchain(s storage.Store, cfg config.ProtocolConfiguration, log *zap.L
|
|||
|
||||
generationAmount: genAmount,
|
||||
decrementInterval: decrementInterval,
|
||||
noBonusHeight: cfg.NoBonusHeight,
|
||||
}
|
||||
|
||||
if err := bc.init(); err != nil {
|
||||
|
@ -1488,9 +1490,14 @@ func (bc *Blockchain) CalculateClaimable(value util.Fixed8, startHeight, endHeig
|
|||
di := uint32(bc.decrementInterval)
|
||||
|
||||
ustart := startHeight / di
|
||||
if genSize := uint32(len(bc.generationAmount)); ustart < genSize {
|
||||
uend := endHeight / di
|
||||
iend := endHeight % di
|
||||
genSize := uint32(len(bc.generationAmount))
|
||||
if ustart < genSize && (bc.noBonusHeight == 0 || startHeight < bc.noBonusHeight) {
|
||||
endHeightMin := endHeight
|
||||
if bc.noBonusHeight != 0 && endHeightMin > bc.noBonusHeight {
|
||||
endHeightMin = bc.noBonusHeight
|
||||
}
|
||||
uend := endHeightMin / di
|
||||
iend := endHeightMin % di
|
||||
if uend >= genSize {
|
||||
uend = genSize - 1
|
||||
iend = di
|
||||
|
|
|
@ -187,6 +187,7 @@ func TestGetClaimable(t *testing.T) {
|
|||
bc.generationAmount = []int{4, 3, 2, 1}
|
||||
bc.decrementInterval = 2
|
||||
_, err := bc.genBlocks(10)
|
||||
bc.noBonusHeight = 6 // stop right before `1`
|
||||
require.NoError(t, err)
|
||||
|
||||
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) {
|
||||
amount, sysfee, err := bc.CalculateClaimable(util.Fixed8FromInt64(1), 1, 7)
|
||||
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)
|
||||
})
|
||||
|
||||
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)
|
||||
require.NoError(t, err)
|
||||
require.EqualValues(t, 4+3+3+2+2+1+1, amount)
|
||||
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) {
|
||||
|
|
Loading…
Reference in a new issue