diff options
| author | Wladimir J. van der Laan <[email protected]> | 2017-04-05 08:36:34 +0200 |
|---|---|---|
| committer | Wladimir J. van der Laan <[email protected]> | 2017-04-05 08:36:52 +0200 |
| commit | f93f9b92969b4a3f77d3f1c2a30ba3bf558e0cac (patch) | |
| tree | 4cb48ee34c21a9592fcc1b9c66d1b7953d827423 | |
| parent | Merge #10133: Clean up calculations of pcoinsTip memory usage (diff) | |
| parent | Bugfix: ancestor modifed fees were incorrect for descendants (diff) | |
| download | discoin-f93f9b92969b4a3f77d3f1c2a30ba3bf558e0cac.tar.xz discoin-f93f9b92969b4a3f77d3f1c2a30ba3bf558e0cac.zip | |
Merge #10144: Prioritisetransaction wasn't always updating ancestor fee
9bef02e Bugfix: ancestor modifed fees were incorrect for descendants (Suhas Daftuar)
ba7dd8b Test prioritisetransaction and ancestor fee state (Suhas Daftuar)
Tree-SHA512: 01977d88e1afb093a003f22a6f29ea60df3d70a179fe7e55910b9c8c340c4af9fb20cdc804c40235b62c43c453f0194eda0d0d4dbd365d2d98347f5dbe5de01c
| -rw-r--r-- | src/txmempool.cpp | 7 | ||||
| -rwxr-xr-x | test/functional/mempool_packages.py | 12 |
2 files changed, 19 insertions, 0 deletions
diff --git a/src/txmempool.cpp b/src/txmempool.cpp index 36a046ed2..0794a3902 100644 --- a/src/txmempool.cpp +++ b/src/txmempool.cpp @@ -912,6 +912,13 @@ void CTxMemPool::PrioritiseTransaction(const uint256& hash, const CAmount& nFeeD BOOST_FOREACH(txiter ancestorIt, setAncestors) { mapTx.modify(ancestorIt, update_descendant_state(0, nFeeDelta, 0)); } + // Now update all descendants' modified fees with ancestors + setEntries setDescendants; + CalculateDescendants(it, setDescendants); + setDescendants.erase(it); + BOOST_FOREACH(txiter descendantIt, setDescendants) { + mapTx.modify(descendantIt, update_ancestor_state(0, nFeeDelta, 0, 0)); + } } } LogPrintf("PrioritiseTransaction: %s feerate += %s\n", hash.ToString(), FormatMoney(nFeeDelta)); diff --git a/test/functional/mempool_packages.py b/test/functional/mempool_packages.py index 17e3a9a96..feec8a7fd 100755 --- a/test/functional/mempool_packages.py +++ b/test/functional/mempool_packages.py @@ -101,6 +101,18 @@ class MempoolPackagesTest(BitcoinTestFramework): assert_equal(mempool[x], v_descendants[x]) assert(chain[0] not in v_descendants.keys()) + # Check that ancestor modified fees includes fee deltas from + # prioritisetransaction + self.nodes[0].prioritisetransaction(chain[0], 1000) + mempool = self.nodes[0].getrawmempool(True) + ancestor_fees = 0 + for x in chain: + ancestor_fees += mempool[x]['fee'] + assert_equal(mempool[x]['ancestorfees'], ancestor_fees * COIN + 1000) + + # Undo the prioritisetransaction for later tests + self.nodes[0].prioritisetransaction(chain[0], -1000) + # Check that descendant modified fees includes fee deltas from # prioritisetransaction self.nodes[0].prioritisetransaction(chain[-1], 1000) |