Merge pull request #1621 from nspcc-dev/core/mempool_fix

core: fix bug with mempool.verifiedMap
This commit is contained in:
Roman Khimov 2020-12-16 14:11:28 +03:00 committed by GitHub
commit ecdf95d5d6
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 4 additions and 1 deletions

View file

@ -216,7 +216,6 @@ func (mp *Pool) Add(t *transaction.Transaction, fee Feer, data ...interface{}) e
mp.oracleResp[id] = t.Hash() mp.oracleResp[id] = t.Hash()
} }
mp.verifiedMap[t.Hash()] = t
if fee.P2PSigExtensionsEnabled() { if fee.P2PSigExtensionsEnabled() {
// Remove conflicting transactions. // Remove conflicting transactions.
for _, conflictingTx := range conflictsToBeRemoved { for _, conflictingTx := range conflictsToBeRemoved {
@ -254,6 +253,7 @@ func (mp *Pool) Add(t *transaction.Transaction, fee Feer, data ...interface{}) e
copy(mp.verifiedTxes[n+1:], mp.verifiedTxes[n:]) copy(mp.verifiedTxes[n+1:], mp.verifiedTxes[n:])
mp.verifiedTxes[n] = pItem mp.verifiedTxes[n] = pItem
} }
mp.verifiedMap[t.Hash()] = t
if fee.P2PSigExtensionsEnabled() { if fee.P2PSigExtensionsEnabled() {
// Add conflicting hashes to the mp.conflicts list. // Add conflicting hashes to the mp.conflicts list.
for _, attr := range t.GetAttributes(transaction.ConflictsT) { for _, attr := range t.GetAttributes(transaction.ConflictsT) {

View file

@ -148,6 +148,9 @@ func TestOverCapacity(t *testing.T) {
txcnt++ txcnt++
require.Error(t, mp.Add(tx, fs)) require.Error(t, mp.Add(tx, fs))
require.Equal(t, mempoolSize, mp.Count()) require.Equal(t, mempoolSize, mp.Count())
require.Equal(t, mempoolSize, len(mp.verifiedMap))
require.Equal(t, mempoolSize, len(mp.verifiedTxes))
require.False(t, mp.containsKey(tx.Hash()))
require.Equal(t, true, sort.IsSorted(sort.Reverse(mp.verifiedTxes))) require.Equal(t, true, sort.IsSorted(sort.Reverse(mp.verifiedTxes)))
// Low net fee, but higher per-byte fee is still a better combination. // Low net fee, but higher per-byte fee is still a better combination.